Javascript闭包的作用与使用方法浅析

 更新时间:2023年01月18日 08:45:31   作者:上官孜然  
闭包是js的一个难点也是它的一个特色,是我们必须掌握的js高级特性,下面这篇文章主要给大家介绍了关于JavaScript闭包函数的相关资料,需要的朋友可以参考下

js 闭包(closure)是Javascript语言的一个难点,也是它的特色。

闭包的作用:通过一系方法,将函数内部的变量(局部变量)转化为全局变量。

要理解闭包,首先必须理解Javascript特殊的变量作用域。

变量的作用域无非就是两种:全局变量和局部变量。

一、变量的作用域

Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量。

var n =999;
function f1(){
	alert(n);
}
f1();    // 999

另一方面,在函数外部无法读取函数内的局部变量。

function f1(){
	var n=999;
}
alert(n);   // error

这里有一个地方需要注意, 函数内部声明变量的时候,一定要使用var命令。如果不用的话,你实际上声明了一个全局变量!

function f1(){
	n=999;
}
f1();
alert(n);   // 999

二、如何从外部读取局部变量

出于种种原因,我们有时候需要得到函数内的局部变量。但是,正常情况下,这是办不到的,只有通过变通方法才能实现。那就是在函数的内部,再定义一个函数。

function f1(){
	var n=999;   
	function f2(){
	alert(n);    // 999
	}
}

在上面的代码中,函数f2就被包括在函数f1内部,这时f1内部的所有局部变量,对f2都是可见的。

但是反过来就不行,f2内部的局部变量,对f1就是不可见的。这就是Javascript语言特有的"链式作用域"结构(chain scope),子对象会一级一级地向上寻找所有父对象的变量。

所以,父对象的所有变量,对子对象都是可见的,反之则不成立。

既然f2可以读取f1中的局部变量,那么只要把f2作为返回值,我们不就可以在f1外部读取它的内部变量了吗!

function f1(){
var n = 999;
	function f2(){
		alert(n); 
	}
	return  f2;
}
var result = f1();
result(); // 999

以上的代码就是js中的闭包

在我的理解中,闭包就是能够读取其他函数内部变量的函数。

由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。

所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。

到此这篇关于Javascript闭包的作用与使用方法浅析的文章就介绍到这了,更多相关Js闭包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Bootstrap3 Grid system原理及应用详解

    Bootstrap3 Grid system原理及应用详解

    这篇文章主要为大家详细介绍了Bootstrap3 Grid system原理及应用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 前端使用正则表达式进行校验的方法总结大全

    前端使用正则表达式进行校验的方法总结大全

    很多时候我们需要校验用户输入的值是否正确,如果格式固定的,直接把错误的值传给后端显然是不合理的,所以我们要直接在前端进行正则校验,这篇文章主要给大家介绍了关于前端使用正则表达式进行校验的相关资料,需要的朋友可以参考下
    2024-07-07
  • JavaScript实现擦玻璃效果分析鼠标移动响应时间粒度问题

    JavaScript实现擦玻璃效果分析鼠标移动响应时间粒度问题

    这篇文章主要为大家介绍了JavaScript实现擦玻璃效果分析鼠标移动响应时间粒度问题详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • JavaScript 字符串处理函数使用小结

    JavaScript 字符串处理函数使用小结

    JavaScript 字符串处理函数使用小结,学习js的朋友可以参考下。
    2010-12-12
  • JS 自动完成 AutoComplete(Ajax 查询)

    JS 自动完成 AutoComplete(Ajax 查询)

    实现类似于百度或谷歌的搜索下拉列表的,就是打开百度往里输入你要查询的条件,只要你一输入他就自动弹出一个下拉列表框,并显示相关所有搜索内容
    2009-07-07
  • javascript 获取图片颜色

    javascript 获取图片颜色

    html 5.0的canvas可以获取到图片的像素点了。这样,我们可以做很多以图片有关的操作和渲染了。当然今后也会给浏览器渲染引擎更高的要求。(YY, 什么时候html渲染引擎也支持多核和GPU呢?)
    2009-04-04
  • 浅谈jQuery异步对象(XMLHttpRequest)

    浅谈jQuery异步对象(XMLHttpRequest)

    文章浅显易懂的将jQuery异步对象分为了5个步奏,非常有利于我们学习记忆,是篇相当不错的学习jQuery异步对象的文章,这里推荐给大家。
    2014-11-11
  • 利用纯js + transition动画实现移动端web轮播图详解

    利用纯js + transition动画实现移动端web轮播图详解

    这篇文章主要给大家介绍了利用纯js + transition动画实现移动端web轮播图的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-09-09
  • JavaScript原型对象、构造函数和实例对象功能与用法详解

    JavaScript原型对象、构造函数和实例对象功能与用法详解

    这篇文章主要介绍了JavaScript原型对象、构造函数和实例对象功能与用法,结合实例形式分析了javascript面向对象相关原型对象、构造函数及实例对象的概念、功能与相关使用技巧,需要的朋友可以参考下
    2018-08-08
  • javascript填充默认头像方法

    javascript填充默认头像方法

    本篇文章通过代码实例给大家讲述了如何javascript填充默认头像以及相代码分享,对此有兴趣的朋友可以学习下。
    2018-02-02

最新评论