1. 作用域
作用域是指可访问的变量和函数的集合。
作用域可分为全局作用域和局部作用域。
1.1 全局作用域
全局作用域是指最外层函数外面定义的变量和函数的集合。
换言之,这些最外层函数外面定义的变量和函数在任何地方都能访问。
举个例子:
// 最外层定义变量 var a = 1; console.log(a); // 最外层可以访问 function fnOne() { // 最外层函数 console.log(a); // 函数内可以访问 function fnTwo() { // 子函数 console.log(a); // 子函数内也可以访问 } } // 说明 在最外面定义一个变量,不仅在最外面可以访问, 在函数内也能访问,在函数的子函数内也能访问。
1.2 局部作用域
局部作用域是指在函数内部定义的变量和函数的集合。
换言之,这些在函数内部定义的变量和函数,在函数外面是无法访问的,只能在函数内部(包括函数的子孙函数)访问。
举个例子:
function fnThree() { // 在函数内定义变量 var b = 2; console.log(b); // 函数内部可以访问 function fnFour() { console.log(b); // 子函数内也能访问 } } // 函数外不能访问 //console.log(b); // 说明 在函数 fnThree 中定义一个变量 b ,在函数内可以访问, 在子函数 fnFour 中也能访问,但在 函数 fnThree 外是不能访问的。
2. 作用域链
从上面的两个例子可以看出,最里层的子函数不仅可以访问最外层函数内的变量,还能访问最外层函数外的全局变量。
这是因为,在创建最外层函数的时候,会把全局作用域拿过来,然后在创建子函数时候,又会把最外层的作用域(包括全局作用域)拿过来,就这样一环扣一环,就形成了作用域链。
所以,作用域链是指内层函数拥有外层函数到最外层(最外层函数外,全局)的所有作用域列表。
3. 闭包
闭包就是能够读取其他函数内部变量的函数。(——百度百科)
从上面的第二个例子可知,函数外是不能访问函数内部定义的局部变量,但是闭包提供了可能。
举个例子:
function User() { // 定义私有变量 var userName = "default"; // 提供 setUserName() 方法 function setUserName(uName) { userName = uName; } // 提供 getUserName() 方法 function getUserName() { return userName; } // 将方法对外开放 return { set: setUserName, get: getUserName } } var user1 = User(); user1.set('tom'); console.log(user1.get()); var user2 = User(); user2.set('jack'); console.log(user2.get()); // 说明 User 函数内部定义变量 uesrName , 并在内部定义两个子函数操作 userName, 最后将两个子函数返回(一个可直接放回,多个可放到对象中返回。)。 这样,在函数外面可以调用子函数访问函数内部的变量, 这两个子函数便实现了闭包的功能。
以上就是详解JavaScript作用域、作用域链和闭包的用法的详细内容,更多关于JavaScript作用域、作用域链和闭包的资料请关注其它相关文章!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“详解JavaScript作用域、作用域链和闭包的用法”评论...
更新动态
2024年12月27日
2024年12月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]