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都是说引用赋值。那么如何解释函数参数都是按值传递的问题呢?

阅读 5k
7 个回答

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

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是一个指针。毕竟指针跟地址值还是不一样的。

你这个例子是按引用传递

b=a

a是一个对象,你把对象的引用地址直接赋给了b那就是a、b共同引用一个变量

基本类型按值传递,对象函数这些按引用传递

var b = a;

a 是一个 对象 {}

所以当

var b = a;

时 就是 把 {} 的指针传给了 b

前几天和遇到了引用赋值的问题。

var a={x:1,y:2}
var b=a; //引用对象
a.z=3; //修改a对象的同时,b也会变;

a==>{x:1,y:2,z:3}
b==>{x:1,y:2,z:3}

当 b=a 时,应该是 b也指向a这个对象变量指向的对象,同时b对象变量被赋值了一个内存地址而这个地址就是a赋值的,所以也是按值传递的;就像var c=1,b;b=c;只不过是赋值的内容不一样,一个是值,一个是内存地址,但是都是值,实实在在的值

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题