码迷,mamicode.com
首页 > 编程语言 > 详细

在JavaScript中引用类型和值类型的区别

时间:2018-06-16 14:25:24      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:bubuko   info   技术   script   ==   color   数据类型   数据   多个   

一、存储方式不一样

基本数据类型

变量存储的是简单的数据段,存储的是具体的值,是轻量级的数据存储方式

引用类型

引用类型的值,可以由多个值构成的对象,引用类型的变量存储的是对象引用地址。引用类型是重量的数据存储方式分配在堆内存频繁创建对象有损性能。

引用类型(N多) Object、Array、Date、Function、……

二、动态属性不一样

1、引用类型能动态添加属性

var person=new Object();

 person.name="jack";

 person.age=20;

 console.log("姓名:%s,年龄:%d",person.name,person.age);

结果

技术分享图片

说明

属性动态添加成功

2、值类型不能添加

三、赋值的方式不一样

1、值类型,拷贝变量的内容

值类型,拷贝变量的内容

var num=10;

var num2=num;//创建新的空间,拷贝num的值到num2

这个两个变量的内容是互不影响的,num2的内容是num的一个副本。类似操作系统的复件

var num=10;

var num2=num;

num2=100;//并不会影响到num的值

console.log("num=%d  num2=%d",num,num2);

结果

技术分享图片

2、引用类型,拷贝引用地址

var person1=new Object();

person1.age=18;

var person2=person1;//拷贝引用地址,给变量person2,于是同时指向一个对象

person2.age=30;//事实上也是person1指向的那个对象

console.log("person1.age=%d   person2.age=%d",person1.age,person2.age);

结果

技术分享图片

说明

两个变量都指向同一个对象,对象就是希望被变量引用的,引用的数量也是没有限制的。

技术分享图片

 

在JavaScript中引用类型和值类型的区别

标签:bubuko   info   技术   script   ==   color   数据类型   数据   多个   

原文地址:https://www.cnblogs.com/cmy1996/p/9190347.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!