JS IF 作用域
2017-09-12 14:39
183 查看
随笔记录一下JS 中使用域自动提升时的一些注意点:
/** * Created by HuangSL on 2017/09/12. */ function testScope() { var funInner = "Inner"; funcOut = "outer"; //没有 var 声明,会被自动提升到 全局作用域 if (true) { var ifInner = "Inner if true"; //变量的作用域被自动提升到 testScope fun ifOuter = "Outer if true"; //没有 var 声明,会被自动提升到 全局作用域 } if (false) { var ifInnerFalse = "Inner if false";//变量的作用域被自动提升到 testScope fun ifOuterFalse = "Outer if false"; //可以防止变量的作用域被自动提升 } console.log(funInner); //Inner console.log(funcOut); //outer console.log(window.funcOut); //outer console.log(ifInner); //Inner if true console.log(ifInnerFalse); //undefined console.log(ifOuter); //Outer if true console.log(window.ifOuter); //Outer if true //console.log(ifOuterFalse);//ReferenceError: ifOuterFalse is not defined } testScope(); /* typeof 可以用来补全一些全局方法或变量 */ //console.log(globalFun);//ReferenceError: globalFun is not defined console.log(typeof globalFun);// "undefined" if (typeof globalFun === "undefined") { globalFun = function () { //不使用 var ,如果变量已经存在,将不会被重复声明,可以防止某些变量重名而出错 console.log("this is my global function;"); } } console.log(typeof globalFun);// "function"
相关文章推荐
- 深扒JS三目运算符的潜力 解决if...else局部作用域问题
- JS的解析顺序和作用域(严格模式)
- js中return的作用
- if IE在html中的作用
- 关于js中if语句成立成立条件的总结
- JS作用域与块级作用域
- Vue.js常用指令汇总(v-if、v-for等)
- JS中的this都有什么作用
- js 中 的 if使用条件
- js 变量,作用域和内存的问题
- Vue.js常用指令汇总(v-if、v-for等)
- urchin.js作用以及urchin.js注释
- js判断一个值是空的最快方法是不是if(!value){alert("这个变量的值是null");}
- js作用域和作用链
- JS运行过程,作用域和上下文的作用,自执行函数
- js变量声明提升,变量作用域与函数作用域,作用域链
- angularjs ng-if表达式为true的情况下标签仍不显示内容
- “#if 0/#if 1 ... #endif”的作用
- js作用域
- js利用运算符优先级实现if else条件判断表达式