JS中基本类型值和引用类型值

一、两者的不同点

1.定义不同:基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象。

2.可以执行的操作不同:对于引用类型的值,可以为其添加属性和方法,也可以改变和删除其属性和方法,举个例子如下:

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

var person = new Object();
person.name = "xiu";
alert(person.name); //xiu
delete person.name;
alert(person.name); //undefined

以上代码创建了对象,并将对象保存在变量"person"中.接着给对象添加一个name属性,并讲字符串“xiu”赋予了这个属性.然后通过alert()函数访问了这个对象的新属性.接着用delete 删除了对象的name属性;

 对于基本类型值,不可以添加属性方法:

var person = "human";
person.name = "xiu";
alert(person.name); //undefined

3.复制变量值的规则不同:

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

var num1 = 5;
var num2 = num1;

num1 中保存的值是5,当使用num1 的值来初始化num2 的值时,num2中也保存了值5,但是num2中的5于num1中的5是完全独立的,该值只是num1 中5的一个副本。这两个变量可以参与任何操作,但不互相影响。

引用类型值复制变量的规则:从一个变量向另一个变量复制一个引用类型值, 同样会在变量对象上创建一个新值,然后把该值复制到新变量分配的位置上。但不同的是,这个被复制的值实际上是一个指针,这个指针指向存储在堆中的一个对象。复制操作结束后,两个变量实际上将引用同一个对象,因此,改变其中一个变量,就会影响 另一个变量,示例如下:

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

二,传递参数

2种方式:按值传递和按引用传递

按值传递:函数的形参是被调用时所传实参的副本,修改形参的值并不会影响实参。

按引用传递:函数的形参接受实参的 隐式引用,而不再是副本。意味着如果形参改变,实参也会被修改。同时两者指向相同的值。 

js中所有函数的参数都是“”按值传递“”参数的。也就是说,把函数外部的值复制给函数内部的参数,就跟把值从一个变量复制到另一个变量一样。

基本类型的值的传递如同基本类型的变量复制一样,引用类型值的传递和引用类型值的变量复制一样。

向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(命名参数,arguments对象中的一个参数)。在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化会反映在函数外部。例子:

function add(num){
    num+=10;
    return num;
}
var A = 10;
var result = add(A);
alert(result); // 20
alert(A);//10
<pre name="code" class="html">
function setName(obj){
    obj.name = "xiu";
}
var person = new Object();
var result = setName(person);
alert(result);//xiu

为了证明对象是按值传递的,再看一下下面这个经过修改的例子:

function setName(obj){
    obj.name = "xiu";
    obj = new Object();
    obj.name = "yang";
}
var person = new Object();
setName(person);
alert(person.name);//xiu

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值