位置: 编程技术 - 正文
推荐整理分享理解和运用JavaScript的闭包机制(理解和运用的重要性要站在哪个的视觉去判断),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:理解和运用重要性要站在什么的角度去判断,理解和运用的重要性要站在哪个的视觉去判断,理解和运用的英文,理解和运用心理健康标准,应注意的问题,理解和运用审计重要性需要站在被审计单位管理层的视角,理解和运用心理健康标准,应注意的问题,理解和运用重要性要站在( )的视角去判断,理解和运用重要性要站在( )的视角去判断,内容如对您有帮助,希望把文章链接给更多的朋友!
伟大的爱因斯坦同志说过:“如果你无法向一个 6 岁小孩解释清楚某问题,那说明你自己都没整明白”。然而,当我向一个 岁的朋友解释什么是闭包时,却彻底失败了。
这原本是国外某哥们儿在 Stack Overflow 上对 JavaScript 闭包所提出的问题。不过既然此问题是在 Stack Overflow 提出的,当然也会有很多高手出来解答,其中有些回答确实是经典,如下面这个:
如果在一个外部函数中再定义一个内部函数,即函数嵌套函数,那么内部函数也可以访问外部函数中的变量:
此段代码可以正确执行,并返回结果:,因为 bar 能访问外部函数的变量 tmp, 同时也能访问外部函数 foo 的参数 x。但以上示例不是闭包!
要实现闭包的话,需要将内部函数作为外部函数的返回值返回,内部函数在返回前,会将所有已访问过的外部函数中的变量在内存中锁定,也就是说,这些变量将常驻 bar 的内存中,不会被垃圾回收器回收,如下:
上述代码中,第一次执行 bar 时,仍会返回结果:,因为 bar 仍然可以访问 x 及 tmp,尽管它已经不直接存在于 foo 的作用域内。那么既然 tmp 被锁定在 bar 的闭包里,那么每次执行 bar 的时候,tmp 都会自增一次,所以第二次和第三次执行 bar 时,分别返回 和 。
此示例中,x 仅仅是个纯粹的数值,当 foo 被调用时,数值 x 就会作为参数被拷贝至 foo 内。
但是 JavaScript 处理对象的时候,使用的总是引用,如果用一个对象作为参数来调用 foo,那么 foo 中传入的实际上是原始对象的引用,所以这个原始对象也相当于被闭包了,如下:
和期望的一样,每次执行 bar() 时,不但 tmp 自增了,x.memb 也自增了,因为函数体内的 x 和函数体外的 age 引用的是同一个对象。
via apply 和 call方法,在函数式编程中也可以用作应用函数。 这里,我们将它们看作是应用函数 —— 应用到参数中的函数(在apply中是参数列表,在call中是独立的参数):
闭包还有另外一个非常重要的应用 —— 延迟调用:
还可以创建封装的作用域来隐藏辅助对象:
再JavaScript的jQuery库中编写动画效果的指南 jquery中常用的动画的方法就是hide()与show().$(element).hide()这段代码可以与这相等element.css("display","none")在hide(time)与show(time)中填入事件,可以慢慢消失跟显
JavaScript变量的作用域全解析 变量作用域是程序中定义这个变量的区域。先来看一段示例:/*代码1*/varscope="global";functioncheckScope(){varscope="local";functionchildCheck(){varscope="childLocal";document.
JavaScript中的this关键字使用详解 和其它许多面向对象的语言一样,JavaScript中也有this关键字,this在函数中用来指向调用此方法的对象。实际编程中要判断this到底指向谁,一般可遵循以
友情链接: 武汉网站建设