JS作用域链初学者

JS作用域链

当代码在一个环境中执行时,会创建变量对象的一个作用域链,作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。活动对象在最开始时只包含一个变量,即arguments对象。作用域链中的下一个变量对象来自包含环境,而再下一个变量对象则来自下一个包含环境。这样,一直延续到全局执行环境;全局执行环境的变量对象始终都是作用域链中的最后一个对象。

1,外部对内部可见
var scope = “g”;
function t(){
console.log(scope); // 打印 g
var scope = “1”; // 当这个不存在时两个都是 g
console.log(scope); // 打印 1
}
t();

2,内部对外部不可见
function t(){
var scope = “1”;
}
t();
console.log(scope); // 报错

3,都可见时,外部优先
var scope = “g”;
function t(){
console.log(scope); // 打印 g
var scope = “1”;
console.log(scope); // 打印 1
}
t();

4,JavaScript中只有函数级别的作用域,没有块级作用域,换句话说,只有在进入或退出函数的时候作用域会发生变化

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值