文章标题

理解javascript变量


遇到某个关于引用类型的函数传递值问题,很久都没有想明白,跟许多前辈讨论了,收获颇多,再重温了高程关于基本类型和引用类型的知识,梳理了一遍并在这写了下了,最后再放上遇到的问题

理解基本类型和引用类型的值

  • 基本类型指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象
  • 5种基本类型的值都是按值访问的,可以操作保存在变量中的实际的值
  • 引用类型的值是保存在内存中的对象,javascript不允许直接操作对象的内存空间,引用类型的值是按引用访问的

动态的添加标题

    var person = new Object();
    person.name = "Nick";
    alert(person.name);  //nick

    var name = "Nick";
    name.age = 27;
    alert(name.age);  //undefined

这段代码说明只能给引用类型动态的添加属性,如果对象不被销毁或者这个属性不被删除,则这个属性将一直存在

复制变量值

如果从一个变量向另一个变量复制基本类型的值,会在变量对象上创建一个新值,然后把该值复制到为新变量分配的位置上

    var num1 = 5;
    var num2 = num1;

复制引用类型的值的副本实际上是一个指针,而这个指针指向存储在堆中的一个对象,改变其中一个变量,就会影响另一个变量

var obj1 = new Object();
var obj2 = obj1;
obj1.name = "nick";
alert(obj2.name);   //"nick"

传递参数

ECMAscript中所有函数的参数都是按值传递的,但访问变量有按值和按引用两种方式

  • 可以把ECMAscript函数的参数想象成局部变量
    在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化会反映在函数的外部
function addTen(num){
    num += 10;
    return num;
}
var count = 20;
var result = addTen(count);
alert(count);  //20,没有变化
alert(result); //30
function setName(obj){
    obj.name = "nick";
}
var person = new Object();
setName(person);
alert(person.name);   //"nick"
function setName(obj){
    obj.name = "nick";
    obj = new Object();
    obj.name = "Greg";
}
var person = new Object();
setName(person);
alert(person.name);   //"nick"

即使在函数内部修改了参数的值,但原始的引用仍然保持不变,而这个局部对象会在函数执行完毕后立即被销毁

题目是这样的


只输出1,2,3

之后有朋友给出了解答

先写这么多吧 日后再来补充

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值