JavaScript数据类型之基本类型和引用类型的值


Posted in Javascript onApril 01, 2015

ECMAScript变量包含两种不同数据类型的值:基本类型值和引用类型值。基本类型值是简单的数据段,而引用类型值指那些可能由多个值构成的对象。

在将一个值赋给变量时,解析器必须确定这个值是基本类型还是引用类型。基本类型包括如Undefined、Null、Boolean、Number和String,这5种基本类型数据类型是按值访问的,因此可以操作保存在变量中的实际的值;引用类型类型的值是保存在内存中的对象。与其他语言不同,JavaScript不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间。在操作对象时,实际上实在操作对象的引用而不是实际的对象,因此,引用类型的值是按引用访问的。

1、动态的属性
    定义基本类型和定义引用类型的方法大相近庭。对于引用类型的值,我们可以为其添加属性和方法,也可以改变和删除其属性和方法,如下:

var person = new Object();

person.name = "zxj";

alert(person.name); //"zxj"    

2、复制变量值

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

var num1 = 5;

var num2 = num1; //5

JavaScript数据类型之基本类型和引用类型的值

 当从一个变量向另一个变量复制引用类型的值时,同样也会将存储在变量对象中的值复制一份放到为新变量分配的内存空间里。不同的是,这个值实际上是一个指针,而这个指针执行存储在堆中的一个对象。复制结束后,两个变量实际上将引用同一个对象。因此,改变其中一个变量,就会影响到另一个变量,如下所示:

var obj1 = new Object();

var obj2 = obj1;

obj1.name = "zxj";

alert(obj2.name); //"zxj"

JavaScript数据类型之基本类型和引用类型的值

3、传递参数

ESMAScript中所有函数的参数都是按值传递的。也就是说,把函数外部的值复制给函数内部的参数,就是把值从一个变量复制到另一个变量一样。基本类型值的传递如同基本类型变量的复制一样。引用类型值的传递,则如同引用类型变量的复制一样。有不少开发者在这一点上可能感到困惑,因为访问变量有按值和按引用两种方式,而参数只能按值传递。

在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(即命名参数)。如下代码所示:

function addTen(num) {

    num += 10;

    return num;

}

var count = 20;

var result = addTen(count);

alert(count); // 20,没有变化

alert(result); // 30

参数实际上是函数的局部变量。参数num和变量count互不认识,它们仅仅具有相同的值。假如num是按引用传递的,那么变量count的值也将变成30,从而反映函数内部的变化。

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

function setName(obj) {

    obj.name = "zxj";

}

var person = new Object();

setName(person);

alert(person.name); //"zxj"

在这个函数内部,obj和person引用的是同一个对象。换句话说,即使这个对象是按值传递的,obj也会按引用来访问同一个对象。于是,当在函数内部为obj添加name属性后,函数外部的person也会有所反映,因为person指向的对象在堆内存中只有一个,而且是全局对象。很多开发者错误的认为:在局部作用域中修改的对象会在全局作用域中反映出来,就说明参数是按引用传递的。为了证明对象是按值传递的,我们在看看下面这个进过修改的例子:

function setName(obj) {

    obj.name = "zxj";

    obj = new Object();

    obj.name = "sdf";

}

var person = new Object();

setName(person);

alert(person.name);

上面这个例子可以看出,如过person是按引用传递的,那么person就会自动被修改为指向其name属性值为"sdf"的新对象。但是,当接下来再访问person.name时,显示的仍然是"zxj"。这说明即使在函数内部修改了参数的值,但原始的引用仍然保存不变。实际上,当在函数内部重写obj时,这个变量引用的就是一个局部对象了。而这个局部对象会在函数执行完毕时立即销毁。

可以将ECMAScript函数的参数想象成局部变量。

4、检测类型

    虽然在检测基本数据类型时typeof是一个得力助手,但是在检测引用类型时,这个操作符用处却不大。通常,我们并不想知道某个值是对象,而是想知道他是什么类型的对象。为此ECMAScript提供了instanceof操作符,其语法如下:

result = varible instanceof constructor

    如果变量是给定引用类型的实例,那么instanceof操作符会返回true:
alert(person instanceof Object);
Javascript 相关文章推荐
文本框中,回车键触发事件的js代码[多浏览器兼容]
Jun 07 Javascript
Javascript事件热键兼容ie|firefox
Dec 30 Javascript
改进UCHOME的记录发布,增强可访问性用户体验
Jan 17 Javascript
js网页侧边随页面滚动广告效果实现
Apr 14 Javascript
jQuery-Easyui 1.2 实现多层菜单效果的代码
Jan 13 Javascript
网站繁简切换的JS遇到页面卡死的解决方法
Mar 12 Javascript
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
超实用的JavaScript代码段 附使用方法
May 22 Javascript
AngularJS 过滤器(自带和自建)详解
Sep 19 Javascript
基于touch.js手势库+zepto.js插件开发图片查看器(滑动、缩放、双击缩放)
Nov 17 Javascript
详解react如何在组件中获取路由参数
Jun 15 Javascript
浅谈React的最大亮点之虚拟DOM
May 29 Javascript
JavaScript之Object类型介绍
Apr 01 #Javascript
JS修改iframe页面背景颜色的方法
Apr 01 #Javascript
JS返回iframe中frameBorder属性值的方法
Apr 01 #Javascript
javascript算法题:求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Apr 01 #Javascript
jQuery scrollFix滚动定位插件
Apr 01 #Javascript
JS动态修改iframe高度和宽度的方法
Apr 01 #Javascript
JS获取iframe中longdesc属性的方法
Apr 01 #Javascript
You might like
防止MySQL注入或HTML表单滥用的PHP程序
2009/01/21 PHP
Yii实现Command任务处理的方法详解
2016/07/14 PHP
javascript showModalDialog 内跳转页面的问题
2010/11/25 Javascript
不使用XMLHttpRequest实现异步加载 Iframe和script
2012/10/29 Javascript
基于JavaScript实现继承机制之原型链(prototype chaining)的详解
2013/05/07 Javascript
js判断两个日期是否相等的方法
2013/09/10 Javascript
JS生成不重复随机数组的函数代码
2014/06/10 Javascript
手机号码,密码正则验证
2014/09/04 Javascript
JavaScript中判断整字类型最简洁的实现方法
2014/11/08 Javascript
jQuery 判断是否包含在数组中Array[]的方法
2016/08/03 Javascript
前端js弹出框组件使用方法
2020/08/24 Javascript
JS实现类似百叶窗下拉菜单效果
2016/12/30 Javascript
老生常谈的跨域处理
2017/01/11 Javascript
jQueryeasyui 中如何使用datetimebox 取两个日期间相隔的天数
2017/06/13 jQuery
利用vscode编写vue的简单配置详解
2017/06/17 Javascript
angular指令笔记ng-options的使用方法
2017/09/18 Javascript
JavaScript数组排序reverse()和sort()方法详解
2017/12/24 Javascript
Vue框架里使用Swiper的方法示例
2018/09/20 Javascript
js判断在哪个浏览器打开项目的方法
2020/01/21 Javascript
JavaScript canvas实现跟随鼠标事件
2020/02/10 Javascript
[03:35]2018年度DOTA2最佳辅助位选手5号位-完美盛典
2018/12/17 DOTA
用python实现批量重命名文件的代码
2012/05/25 Python
理解Python中的With语句
2015/02/02 Python
Python简单删除目录下文件以及文件夹的方法
2015/05/27 Python
tensorflow学习教程之文本分类详析
2018/08/07 Python
Apache部署Django项目图文详解
2019/07/30 Python
HTML5 Canvas中绘制矩形实例
2015/01/01 HTML / CSS
Html5之webcoekt播放JPEG图片流
2020/09/22 HTML / CSS
项目合作意向书范本
2014/04/01 职场文书
数学教育专业求职信
2014/07/22 职场文书
教师年终个人总结
2015/02/11 职场文书
2015年招商引资工作总结
2015/04/25 职场文书
独生子女证明范本
2015/06/19 职场文书
初中同学会致辞
2015/08/01 职场文书
2015小学新教师个人工作总结
2015/10/14 职场文书
oracle重置序列从0开始递增1
2022/02/28 Oracle