javascript - JS引用赋值,按值赋值的理解

查看:53
本文介绍了javascript - JS引用赋值,按值赋值的理解的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

var a={i:1};//引用赋值。
var b=a;   //按值赋值?a把它指向对象{i:1}的地址copy给b。 
a.i=2;
console.log(b.i) //2

  1. b=a是不是按值赋值呢?

  2. 大家的回答,b=a都是说引用赋值。那么如何解释函数参数都是按值传递的问题呢?

解决方案

基本类型按值传递(复制),对象按共享传递(两个对象共享一个内存地址),也可以理解为按引用传递(指向同一块内存空间)。函数参数传递方式看参数的类型,并不全是按值传递;

var a = {name:'aaa', age:22};
function b(o){
    o.name = "bbb"
    console.log(o);
}
b(a);
a

输出:
Object {name: "bbb", age: 22}
Object {name: "bbb", age: 22} // 错误观点:如果是按值传递,a里面的name就不应该改变。
/*其实是变量o复制了变量a的地址值,这个地址指向了a指向的那个对象,
 *所以改变o的属性值,即是改变了指向那个对象的属性值,
 *这里o已经是一个函数b的局部变量了。
*/

更正一下:函数参数确实是按值传递的,只不过不同的类型传递的值不同,基础类型copy是值,引用类型copy的是地址值,而引用类型变量的复制,copy是一个指针。毕竟指针跟地址值还是不一样的。

这篇关于javascript - JS引用赋值,按值赋值的理解的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆