《你不知道的JavaScript(上卷)》笔记:函数作用域和块作用域
2018-03-04 17:44
295 查看
函数作用域:属于这个函数的全部变量都可以在整个函数的范围内使用及复用。
最小暴露原则:应该最小限度地暴露必要内容,而将其他内容都“隐藏”起来,比如某个模块或对象的API设计。
始终给函数表达式命名,是一个最佳实践。
匿名函数需要考虑的几个方面
匿名函数咋栈追踪不会显示有意义的函数名,使得调试困难;
如果没有函数名,当函数需要引用自身只能使用已经过期的arguments.callee引用,比如在递归中。另一个函数需要引用自身的例子,是在事件触发后事件监听器需要解绑自身。
匿名函数省略了对于代码可读性、可理解性很重要的函数名,一个描述性的名称可以让代码不言自明。
块作用域
with
try/catch
JavaScript的ES3规范中规定try/catch的catch分句会创建一个块作用域,其中声明的变量仅在catch内部有效。
但是,try/catch的性能很糟糕。
let
使用let进行的声明不会在块作用域中进行提升,声明的代码运行之前,声明不“存在”。
特别的用处:
a. 垃圾收集
b. for循环中使用let声明循环变量
const
最小暴露原则:应该最小限度地暴露必要内容,而将其他内容都“隐藏”起来,比如某个模块或对象的API设计。
始终给函数表达式命名,是一个最佳实践。
匿名函数需要考虑的几个方面
匿名函数咋栈追踪不会显示有意义的函数名,使得调试困难;
如果没有函数名,当函数需要引用自身只能使用已经过期的arguments.callee引用,比如在递归中。另一个函数需要引用自身的例子,是在事件触发后事件监听器需要解绑自身。
匿名函数省略了对于代码可读性、可理解性很重要的函数名,一个描述性的名称可以让代码不言自明。
setTimeout(function timeoutHandler() { console.log( "I waited 1 second!" ); }, 1000);
块作用域
with
try/catch
JavaScript的ES3规范中规定try/catch的catch分句会创建一个块作用域,其中声明的变量仅在catch内部有效。
但是,try/catch的性能很糟糕。
let
使用let进行的声明不会在块作用域中进行提升,声明的代码运行之前,声明不“存在”。
特别的用处:
a. 垃圾收集
b. for循环中使用let声明循环变量
const
相关文章推荐
- 《你不知道的javascript》一、函数作用域和块作用域
- JavaScript笔记:函数作用域和块作用域
- 《你不知道的JavaScript(上卷)》笔记:词法作用域
- 你不知道的Javascript(上卷)读书笔记之三 ---- 函数作用域与块作用域
- 函数作用域和块作用域
- iOS开发学习笔记 2-6 C语言部分 函数及变量的作用域
- js没有块级作用域但有函数作用域
- JavaScript学习笔记(函数与作用域)
- unix学习笔记-------利用dup()函数来达到共享同一个文件表项的作用
- 装饰器学习笔记1:函数的作用域
- linux shell学习笔记二---自定义函数(定义、返回值、变量作用域)介绍
- 神经网络学习笔记 - 激活函数的作用、定义和微分证明
- js12--块作用域函数作用域
- Javascript学习笔记之函数篇(六) : 作用域与命名空间
- 《你不知道的JavaScript(上卷)》笔记:作用域闭包
- 读书笔记《你不知道的JavaScript上卷》1.3函数作用域和块作用域
- Coffee script 学习笔记I --函数及变量作用域
- 函数作用域和块级作用域?
- 你不知道的javascript之函数作用域和块作用域(一)
- 【学习笔记六】 - js中 创建对象的模式与继承 及 js中实现块级作用域和函数私有变量 《js高程》6-7笔记