JavaScript 作用域 理解
2016-07-05 16:23
316 查看
没有var 声明的变量都是全局变量,而且为window对象的属性 ,可以删除,var 声明的不可以删除;
函数内(函数内的函数除外)声明的变量在整个函数内部有效;(不管在函数内什么位置,顶部or底部都是有效的)
函数内部的变量取代全局同名变量;
函数作用域的嵌套关系是定义时决定的,而不是调用时决定的,也就 是说,JavaScript 的作用域是静态作用域,又叫词法作用域,这是因为作用域的嵌套关系可 以在语法分析时确定,而不必等到运行时确定
Javascript没有代码块作用域的概念,局部作用域是针对函数来说的。
function fun02() { a = "helloworld"; var b = "welcome"; } fun02(); console.log(a); // helloworld console.log(b); // b is not defined
函数内(函数内的函数除外)声明的变量在整个函数内部有效;(不管在函数内什么位置,顶部or底部都是有效的)
函数内部的变量取代全局同名变量;
函数作用域的嵌套关系是定义时决定的,而不是调用时决定的,也就 是说,JavaScript 的作用域是静态作用域,又叫词法作用域,这是因为作用域的嵌套关系可 以在语法分析时确定,而不必等到运行时确定
Javascript没有代码块作用域的概念,局部作用域是针对函数来说的。
function fun() { for( var i = 0 ; i < 10 ; i++) {} //如果在Java中i此时应当属于未声明的变量,但是Js中i的作用域依然存在 console.log(i);//10 if(true) { var b = "helloworld"; } console.log(b);//helloworld } fun();
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享