变量
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中没有块级作用域。