JavaScript中的变量

基本类型与引用类型

ECMAScript变量包含两种不同数据类型的值:基本类型值和引用类型值。

基本类型值:指简单的数据段。一共有五种基本数据类型:Number,String,Boolean,Null,Undefined。这五种基本数据类型是按值访问的,因为可以操作保存在变量中的实际的值。

引用类型值:指保存在内存中的对象。与其他语言不同,JS不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间。在操作对象时,实际上是在操作对象的引用而不是实际的对象。因此,引用类型的值是按引用访问的。实际上这种说法不够严密,因为在复制保存着对象的某个变量时,操作的是对象的引用,但是在为对象添加属性或方法时,操作的是实际的对象。

基本类型与引用类型的区别

1.可执行操作不同 

     对基本类型的值,添加属性尽管不会报错,但是添加无效   

var name="TOM";
name.age=21;
alert(name.age); //undefined

     对引用类型的值,可以为其添加属性和方法,也可以改变和删除其属性和方法

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

2.复制变量值的规则不同

   如果从一个变量向另一个变量复制基本类型的值,会将存储在变量对象中的值复制一份到为新变量分配的空间上。基本类型值在内存中占据固定大小的空间,因此被保存在栈内存中。

var a=5;
var b=a;
a=6;
alert(a); //6
alert(b); //5

   当从一个变量向另一个变量复制引用类型的值时,同样也会将存储在变量对象中的值复制一份放到为新变量分配的空间中。不同的是,这个值的副本实际上是一个指针,而这个指针指向存储在堆中的一个对象。复制操作结束后,两个变量实际上将引用同一个对象。因此,改变其中一个变量,就会影响另一个变量。即引用类型的值是对象,保存在堆内存中,但指向它的指针保存在栈内存中。

var person1 = new Object();
person1.name= "TOM";
var person2 = person1;
person2.name= "JACK";
alert(person1.name);  //JACK
alert(person2.name);  //JACK

 

3.传递参数不同

    ECMAScript中所有函数的参数都是按值传递的。也就是说,把函数外部的值赋给函数内部的参数,就和把值从一个变量复制到另一个变量一样。基本类型值的传递如同基本类型变量的复制一样,引用类型值的传递就如同引用类型变量的复制一样。

在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量。

在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化会反映在函数的外部。

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值