细说javascript作用域

javascript作用域是一个老生常谈的问题,现在我就以最简单的方式去理解一下作用域这个概念。
在javascript里面没有块级作用域的区分,也不要把作用域的概念和上下文来混淆,javascript的作用域是由函数划分开的。
先来看一个demo:
var xisa = 'test';

// 在{}块里面
{
    // 这里没有块级的概念 所有xisa这个变量还是属于全局作用域!
    var xisa = 'new test';
}

// 输出为true
console.info( xisa === 'new test' );

// 创建新函数
function fn() {
    var xisa = "fn test";
}

// 直接在全局作用域执行 但是xisa只有在fn函数内部起作用
fn();

// 输出还是为true
console.info( xisa === 'new test' );
从上面的demo可以看出来,xisa这个变量只会在全局作用域起作用,fn函数里面重新声明一个xisa变量,这个变量只会在fn内部起作用,这就是作用域; 所有全局变量都是属于window对象的属性,比如直接打印 window.xisa,会直接输出'new test',所以上面的demo展示了全局作用域和局部作用域。
在javascript里面如果不做变量声明,则此变量就会变成隐式全局作用域,如下:
// 在一个fn方法里面写一个没有声明的xisa变量
function fn() {
    xisa = 'test';
}

// 直接调用
fn();

// 输出test
console.info( window.xisa )

这样的写法会污染全局变量,虽然javascript是一门不严谨的语言,但是如果这样的写法多了之后,就很不方便维护,所以尽量要先声明变量再去调用。


如果有错误或者不爽的地方欢迎来喷我: https://github.com/gtdalp   emoticon

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值