JavaScript引用类型和基本类型的区别

62 阅读1分钟
var obj1={name:'Tom'}
        var obj2=obj1
        obj2.age=12
        console.log(obj1.age);
        function fn(obj){
            obj.name='A'
        }
        fn(obj1)
        console.log(obj2.name)
        console.log(obj1.name)

输出结果为 12 A A 基本类型相互传递的是值 上面的代码为引用类型他们传递的为地址值,不能说是地址。通过变量修改对象类型中的数据,所有通过引用类型的看到的都是修改以后的的数据

	1	var a={age:12}
    2   var b=a;
    3   a={name:'bob',age:13}
        console.log(b.age,a.name,a.age)//12 Bob 13

当我们用对象赋值时我们将开辟新的空间

变量名空间数(空间序号)
语句1:开辟了1空间指向A1(空间1)
语句2:将空间1的地址值指向b1(空间1)
语句3:开辟了2空间指向A2 (空间1,空间2)

所以此时的a和b指向的是不同空间他们是不互相影响

	1	var a={age:12}
    2   var b=a;
    3   a={name:'bob',age:13}
        console.log(b.age,a.name,a.age)//12 Bob 13
    4   function fn2 (obj){
    5      obj={age:15}
        }
    6   fn2(a)
        console.log(a.age)//13
变量名空间数(空间序号)
语句1:开辟了1空间指向A1(空间1)
语句2:将空间1的地址值指向b1(空间1)
语句3:开辟了2空间指向A2 (空间1,空间2)
语句4:将空间2指向obj2 (空间1,空间2)
语句5:开辟了3空间指向obj3 (空间1,空间2,空间3)
语句6:此时的a还是指向空间空间2和obj脱离关系3 (空间1,空间2,空间3