JavaScript中的变量复制,传参与作用域问题

变量

ECMAScript变量包含两种类型:基本类型(5)和引用类型。基本类型是按值访问的,引用类型是按引用(内存的地址)访问的。只有引用类型能动态的添加属性。

除了保存类型不同外,变量复制与参数传递也不同。基本类型复制会创建一个新值,将该值分配到为新变量分配的位置;引用类型复制将对象在内存中的地址(指针)付给新值。

ECMAScript中所有函数的参数都是值传递。在向函数传递参数时,被传递的值会被复制给一个局部变量(即命名参数)。在向参数传递引用类型时,会将这个值的指针付给局部变量。


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

类型检测

检测变量是否为基本类型可以使用typeof操作符。

语法:typeof 变量;

typeof对基本类型会返回相应字符串,但对null除外,null和Object会返回”object”,函数会返回”function”。

var message = "liuli";
alert(typeof message); //"string"

此外,ECMAScript提供instanceof操作符检测特定应勇类型,语法如下:

 var result = 变量  instanceof  给定引用类型构造函数名
例如:
var nums = new Array();
alert(nums instanceof Object); //true

如果变量是给定引用类型,instanceof将会返回true。因为所有引用类型都是Object的实例,故在检测一个引用类型和Objiect构造函数时总会返回true。

执行环境及作用域

执行环境定义了变量或函数有权访问的其他数据,决定他们各自的行为。每个执行环境都有一个变量对象,其中保存了环境中定义的所有变量和函数。

每个函数都有自己的执行环境。当代码在一个环境中执行时,会创建变量对象的一个作用域链,保证对执行环境有权访问的所有变量和函数的有序访问。执行环境的最前端是当前执行代码所在环境的变量对象。

延长作用域链

  • with语句
  • try-catch中的catch块
这两个语句都会在作用域前端加一个变量对象。
function buildUrl() {
with(location){
var url = href + qs;// url声明在函数的作用域中(最近的环境)
}
return url;
}
with将location对象添加到作用域链前端。

注:js中没有块级作用域。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值