search
HomeWeb Front-endJS TutorialA brief analysis of javascript closure (Closure) usage examples_javascript skills

The example in this article describes the usage of javascript closure (Closure). Share it with everyone for your reference, the details are as follows:

closure is translated as "closure", and I feel that this thing is packaged in a too academic way. Let’s briefly discuss it with reference to books and online resources (please pay attention to any inappropriate understanding).

1. What is closure

Official answer: The so-called "closure" refers to an expression (usually a function) that has many variables and an environment bound to these variables, so these variables are also part of the expression.

After reading the above definition, if you are not an expert, I firmly believe that you will ask angrily like me: Is this tmd human language?
To understand closures, code is the most convincing. Here is the code:

function funcTest()
{
 var tmpNum=100; //私有变量
 //在函数funcTest内定义另外的函数作为funcTest的方法函数
 function innerFuncTest(
 {
    alert(tmpNum); //引用外层函数funcTest的临时变量tmpNum
 }
 return innerFuncTest; //返回内部函数
}
//调用函数
var myFuncTest=funcTest(); 
myFuncTest();//弹出100

In the above code, the comments have been written clearly. Now we can understand "closure" like this: define another function in the function body as the method function of the target object (in the example, define another function innerFuncTest as the method function of funcTest within the function funcTest), and the method function of this object is the opposite. Come to reference the temporary variables in the outer function body (closure is a mechanism to indirectly maintain variable values. In the example, the inner function innerFuncTest refers to the temporary variable tmpNum of the outer function funcTest. It must be noted here that temporary variables can be included in the outer function. all declared local variables, parameters, and other declared internal functions). When one of these inner functions is called outside the outer function that contains them, a closure is formed (in the example, when calling the function, myFuncTest actually calls the innerFuncTest function, which means that an inner function of funcTest, innerFuncTest is called outside funcTest, a closure is created).

2. Two examples of using closures

Here are two examples. One is because closures cause problems, and the other uses closures to cleverly bind parameters through the scope of a function.

The HTML markup fragments related to these two examples are as follows:

<a href="#" id="closureTest0">利用闭包的例子(1秒后会看到提示)</a><br />
<a href="#" id="closureTest1">由于闭包导致问题的例子1</a><br />
<a href="#" id="closureTest2">由于闭包导致问题的例子2</a><br />
<a href="#" id="closureTest3">由于闭包导致问题的例子3</a><br />

(1) Problems caused by closures

There are 4 elements in the above HTML tag fragment. Now we need to assign event handlers to the last three so that they report their order in the page when the user clicks. For example: when the user clicks When linking to the 2nd link, it reports "You clicked on the 1st link". To do this, if you write the following function that adds event handlers for the last three links:

function badClosureExample(){
  for (var i = 1; i <4; i++) {
    var element = document.getElementById('closureTest' + i);
    element .onclick = function(){
      alert('您单击的是第' + i + '个链接');
    }
  }
}

Then, call this function after the page is loaded (otherwise an error may be reported):

window.onload = function(){
  badClosureExample();
}

Look at the running results. If you click on the last three links, what information will you see in the warning box? ——It's all "You clicked on the 4th link". Does it surprise you? Why?

Analysis: Because the event handler assigned to element.onclick in the badClosureExample() function, that is, the onclick anonymous function is only called after the badClosureExample() function completes (when the user clicks the link). When calling, the variable i needs to be evaluated. The parser will first search inside the event handler, but i is not defined. Then, search in the badClosureExample() function. It is defined at this time, but the value of i is 4 (the for loop will stop executing only if i is greater than 4). Therefore, that value is obtained - exactly what the closure (anonymous function) would do if it were to use a variable in the scope of its outer function (badClosureExample). Moreover, this is also caused by the fact that the anonymous function itself cannot pass parameters (and therefore cannot maintain its own scope).

So how to solve the problem in this example? In fact, there are many methods (you might as well write it yourself and see). I think the code is relatively simple and direct:

function popNum(oNum){
  return function(){
          alert('您单击的是第'+oNum+'个链接');
  }
}
function badClosureExample(){
  for (var i = 1; i <4; i++) {
    var element = document.getElementById('closureTest' + i);
    element .onclick =new popNum(i);
    }
}

(2), clever use of closures to bind parameters

Still with the above HTML fragment, we want to delay popping up a warning box when the user clicks the first link. How to achieve this? The answer is to use the setTimeout() function, which calls a function after a specified number of milliseconds, such as:

Copy code The code is as follows:
setTimeout(someFunc,1000);

But the problem is that parameters cannot be passed to someFunc function. This problem can be easily solved using closures:
function goodClosureExample(oMsg){
  return function(){
    alert(oMsg);
  };
}

The function goodClosureExample is used to return an anonymous function (closure). And we can make the returned anonymous function bind the parameter by passing it a parameter, such as:

Copy code The code is as follows:
var good = goodClosureExample('This parameter is bound through a closure');

而此时,就可以将绑定了参数的good函数传递给setTimeout()实现延时警告了:
复制代码 代码如下:
setTimeout(good,1000) //此时good中已经绑定了参数

最后,测试通过的完整代码:
window.onload = function(){
  var element = document.getElementById('closureTest0');
  if (element) {
    var good = goodClosureExample('这个参数是由闭包绑定的');
    element.onclick = function(){
      setTimeout(good, 1000); //延迟1秒弹出提示
    }
  }
}

3、javascript的垃圾回收原理

(1)、在javascript中,如果一个对象不再被引用,那么这个对象就会被GC回收;

(2)、如果两个对象互相引用,而不再被第3者所引用,那么这两个互相引用的对象也会被回收。

在js中使用闭包,往往会给javascript的垃圾回收器制造难题。尤其是遇到对象间复杂的循环引用时,垃圾回收的判断逻辑非常复杂,搞不好就有内存泄漏的危险,所以,慎用闭包。ms貌似已经不建议使用闭包了。

希望本文所述对大家JavaScript程序设计有所帮助。

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach是es6里的吗foreach是es6里的吗May 05, 2022 pm 05:59 PM

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft