<script type="text/javascript"> function fn() { var i = 10; return function (n) { console.log(n + (++i)) } } var f = fn();//首先把fn执行,然后把执行的结果赋值给f,函数执行只要看函数里面有没有return f(10);//10+11=21; f(20);//20+12=32; fn()(10);//10+11=21 fn()(20)//20+11=3…
javascript中的作用域(scope)和上下文(context)是这门语言的独到之处,这部分归功于他们带来的灵活性.每个函数有不同的变量上下文和作用域.这些概念是javascript中一些强大的设计模式的后盾.然而这也给开发人员带来很大困惑.下面全面揭示了javascript中的上下文和作用域的不同,以及各种设计模式如何使用他们. 上下文 vs 作用域 首先需要澄清的问题是上下文和作用域是不同的概念.多年来我注意到许多开发者经常将这两个术语混淆,错误的将一个描述为另一个.平心而论,这些术语…
原文:http://www.adequatelygood.com/JavaScript-Scoping-and-Hoisting.html ===翻译开始=== 你知道下面的JavaScript脚本执行结果是什么吗? var foo=1; function bar(){ if(!foo){ var foo=10; } alert(foo); } bar(); 如果你对弹出的结果是"10"感到惊讶的话,那么下面这段脚本会让你晕头转向的: var a=1; function b(){ a=…