《JavaScript权威指南》第四章——变量

4.1 变量的类型

JS变量可以存放任意类型的值。

4.2 变量的声明

使用var关键字表示声明。

声明但未赋值时,变量的值是undefined。

使用var声明的变量是永久性的,尝试用delete运算符删除会引发错误。

使用var重复声明一个变量是合法的。

如果给一个没有使用var声明的变量赋值,该变量会被声明为全局变量,即使此声明发生在一个函数体内部。由此可知,如果想声明为局部变量,就必须使用var关键字。

4.3 变量的作用域

全局作用域,局部作用域。

JavaScript中没有块级作用域,即函数中声明的所有变量在整个函数中都有定义,但是在执行var语句之前,变量不会被初始化。

var scope = "global";
function f () {
    alert(scope); // Display "undefined"
    var scope = "local";
    alert(scope); // Display "local"
}
f ();
golo:“经试验,全局变量也适用此规则,但是声明时必须显式地使用var,如果使用直接给未声明的变量赋值的方式声明全局变量,此规则无效。”
所以,将所有的变量声明都集中在函数的开头是一个好的编程习惯。

尝试给未声明的变量赋值,程序会隐式地将其声明未全局变量。

尝试读取未声明的变量时,会报错。

4.4 基本类型和引用类型

变量保存基本类型的实际值,保存引用类型的引用。

基本类型:数值、布尔值、null和undefined。具有固定长度。

引用类型:对象、数组、函数。没有固定长度。

特例:字符串。没有固定长度,但长度不可变。

4.5 垃圾收集

4.6 作为属性的变量

全局对象VS调用对象

①全局对象只有一个,每个函数对应一个调用对象。

②全局变量是全局对象的属性,局部变量和函数的参数是调用对象的属性。

用一个完全独立的对象来存储局部变量使JavaScript可以防止局部变量覆盖同名的局部变量的值。

JavaScript的执行环境(此处需要再次阅读理解)

JavaScript的解释器每次开始执行一个函数时,都会为那个函数创建一个执行环境(execution context)。

4.7 深入理解变量作用域

每个JavaScript执行环境都有一个和它关联在一起的作用域链(scope chain)。这个作用域链是一个对象列表或对项链。

对于顶层代码:作用域链只有全局对象。

对于(非嵌套的)函数:作用域链包括调用对象和全局对象。

对于(嵌套的)函数:作用域链报错多个调用对象和全局对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值