首页 > 编程语言 > 详细

《你不知道的javascript》【1】——词法/函数/块作用域

时间:2020-06-26 11:34:09      阅读:75      评论:0      收藏:0      [点我收藏+]

 

你不知道的JavaScript(上卷)

 
 

视频选集

1/4

 

技术分享图片

 

 

技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 

技术分享图片

 

 技术分享图片

 

 技术分享图片

 

欺骗词法:

作用域恶魔

 

技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 

另外一个不推荐使用 eval(..) 和 with 的原因是会被严格模式所影响(限 制)。with 被完全禁止,而在保留核心功能的前提下,间接或非安全地使用 eval(..) 也被禁止了。

技术分享图片

 

 

技术分享图片

 

 

隐藏函数内部实现

 

技术分享图片

 

 for 循环永远不会停止

var i 在全局作用域,每次调用 bar 函数就会被重置为3

 

解决方案之一:

技术分享图片

 

 

解决方案二:

技术分享图片

 

 类似地:模块封装

 

技术分享图片

 

 

 

技术分享图片

 

技术分享图片

 

 

具名:自身的引用更容易

技术分享图片

 

 

 

 

技术分享图片

 

 技术分享图片

 技术分享图片

 

 

技术分享图片

 

 技术分享图片

 

 

UMD模式:

技术分享图片

 

 

块作用域:

js 里面 if else 并没有实现块作用域

 

with 是一个块级作用域

技术分享图片

 

 

try catch 

技术分享图片

 

 

 

es6:let / const

技术分享图片

 

 

var 改 let,则只作用于块内

 

技术分享图片

 

 

技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

 技术分享图片

 

变量的声明:编译阶段;

变量的赋值:运行阶段;

 

技术分享图片

 

 

 

函数声明也会提升(比如 下面报的不是 type error : foo is not a func 错误

技术分享图片

 

 

技术分享图片

 

 提升只适用于作用域内

var a=2 并不在外面的作用域,所以console.log(a) 就是 not defined 错误了

 

技术分享图片

 

 

重复的 var 声明会被忽略掉(再次声明直接取前续声明的LHS地址),但出现在后面的函数声明还是可以覆盖前面的 

函数重复声明:后面的声明会覆盖前面的声明

 

技术分享图片

 

 

技术分享图片

 

 

技术分享图片

 

 

let 和 const 关键字不会造成提升

 

 

《你不知道的javascript》【1】——词法/函数/块作用域

原文:https://www.cnblogs.com/cx2016/p/13193878.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!