规避冲突
// 11无限死循环
区分函数声明和函数表达式最简单的方法是看 function 关键字出现的位置,如果function是声明中的第一个词,那么是函数声明,否则是函数表达式。
(function foo(){})() 立即执行的函数表达式
IIFE 立即执行函数表达式
将window 对象的引用传递进去,当然可以从外部作用域传入进任何你需要的东西,
并可以将变量命名为任何你觉得合适名字。
函数表达式def 定义在片段的第二部分,然后当做参数被传递进IIFE 函数定义的第一部分中。最后def也就是传递进去的函数被调用,并将window 传入当做global参数的值。
try/catch 的catch 分句会创建一个块级 作用域,其中声明的变量仅在catch内部有效
例如:try{
undefinde();
}catch (err){
console,log(err); // 能够正常使用
}
console.log(err) // ReferenceError: err not found
let 块作用域
变量提升,先有声明后又赋值。
原因:相当于以下
注意: 函数声明会被提升,函数表达式不会被声明。函数和变量都会被提升,但是函数会被提前提升,然后是变量。
const 常量
后面的函数声明会覆盖前面的
var a = 2 ; 的解析原则是 var a 和 a = 2 当做两个单独的声明,第一个是编译阶段的
任务,第二个是执行阶段的任务。
闭包
在迭代器内部使用IIFE会为每一个迭代都生成一个新的作用域。
块作用域和闭包联手
模块
改为单例模式: