闭包实现按钮状态切换
看下面的代码:
var toggleBtn = document.getElementById('toggle'); var toggleFun = (function() { var checked = true; return function() { var color = checked "color: #ff0000">解释上面的代码实现了点击按钮切换样式的功能,它用到了js的闭包特性。简单解释下:
toggleFun为一个立即执行函数,执行后toggleFun被赋值为内部函数:
toggleFun = function() { color = checked "htmlcode">var toggleBtn = document.getElementById('toggle'); var outerFun = function() { var checked = true; // innerFun声明时用到了outerFun的局部变量 var innerFun = function() { var color = checked "color: #ff0000">不用闭包,用全局变量其实不用闭包也能实现按钮切换,不过就得用到全局变量来存储按钮状态:
var toggleBtn = document.getElementById('toggle'); var checked = true; // 全局变量存储按钮状态 var toggleFun = function() { var color = checked "color: #ff0000">补充:JavaScript闭包的概念及用法1.闭包的概念:
闭包就是能够读取其他函数内部变量的函数.
例如:
function f1(){ var n=999; function f2(){ alert(n); } return f2; } var result=f1(); result(); // 999其中f2函数就是闭包。
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,
因此可以把闭包简单理解成"定义在一个函数内部的函数"。
所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
2.闭包的用途:
闭包可以用在许多地方。它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,
另一个就是让这些变量的值始终保持在内存中。
怎么来理解这句话呢?请看下面的代码。
function f1(){ var n=999; nAdd=function(){n+=1} function f2(){ alert(n); } return f2; } var result=f1(); result(); // 999 nAdd(); result(); // 1000在这段代码中,result实际上就是闭包f2函数。它一共运行了两次,第一次的值是999,
第二次的值是1000。这证明了,函数f1中的局部变量n一直保存在内存中,并没有在f1调用后被自动清除。
为什么会这样呢?原因就在于f1是f2的父函数,而f2被赋给了一个全局变量,这导致f2始终在内存中,
而f2的存在依赖于f1,因此f1也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收。
这段代码中另一个值得注意的地方,就是"
nAdd=function(){n+=1}"
这一行,首先在nAdd前面没有使用var关键字,因此nAdd是一个全局变量,而不是局部变量。
其次,nAdd的值是一个匿名函数(anonymous function),而这个匿名函数本身也是一个闭包,
所以nAdd相当于是一个setter,可以在函数外部对函数内部的局部变量进行操作。
总结
以上所述是小编给大家介绍的javascript闭包的使用之按钮切换功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
DDR爱好者之家 Design By 杰米
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 薰妮1980-相逢有如梦中[香港永恒真存珍藏版][WAV+CUE]
- 吴俊宏.2012-无名的英雄【豪记】【WAV+CUE】
- 周国贤.2016-风起BreezeOut【维高文化】【FLAC分轨】
- 群星.2012-顾听生辉·乐坛大宗师经典半世纪3CD【环球】【WAV+CUE】
- 王瑞霞.1991-绝情雨【名冠】【WAV+CUE】
- 群星.2024-在暴雪时分电视剧影视原声带【SONY】【FLAC分轨】
- 陈楚生.2022-涂鸦森林【华声时代】【FLAC分轨】
- 《张国荣 金曲回顾》[WAV+CUE][460MB]
- 缇ゆ槦銆婃ⅵ閱夊績澹般€媅WAV+CUE][698M]
- 群星《伤心城市·车舞慢嗨》2CD[WAV分轨][1.4G]
- 陈百强.2003-完全陈百强5CD【华纳】【WAV+CUE】
- 蔡依林.2006-舞娘【EMI百代】【WAV+CUE】
- 五月天.2007-为爱而生【滚石】【WAV+CUE】
- 群星1993-巨石1994送旧迎新[巨石][WAV+CUE]
- 群星1995-风中奇缘电影原声带(国际中文版)[迪斯尼][WAV+CUE]