About let to avoid problems caused by closure
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!--code here--> <title>demo</title> <style> * { padding: 0; margin: 0; } .head, li div { display: inline-block; width: 70px; text-align: center; } li .id, li .sex, .id, .sex { width: 15px; } li .name, .name { width: 40px; } li .tel, .tel { width: 90px; } li .del, .del { width: 15px; } ul { list-style: none; } .user-delete { cursor: pointer; } </style> </head> <body> <div id="J_container"> <div class="record-head"> <div class="head id">Serial number</div> <div class="head name">Name</div> <div class="head sex">Gender</div> <div class="head tel">Phone number</div> <div class="head province">Province</div> <div class="head">Operation</div> </div> <ul id="J_List"> <li> <div class="id">1</div> <div class="name">Zhang San</div> <div class="sex">Male</div> <div class="tel">13788888888</div> <div class="province">Zhejiang</div> <div class="user-delete">Delete</div> </li> <li> <div class="id">2</div> <div class="name">Li Si</div> <div class="sex">female</div> <div class="tel">13788887777</div> <div class="province">Sichuan</div> <div class="user-delete">Delete</div> </li> <li> <div class="id">3</div> <div class="name">Wang Er</div> <div class="sex">Male</div> <div class="tel">13788889999</div> <div class="province">Guangdong</div> <div class="user-delete">Delete</div> </li> </ul> </div> <script> // You can also use ES6 here function Contact() { this.init(); } // your code here </script> </body> </html> code1
code2 (other people's code) Contact.prototype.init = function () { console.log("Test"); var div = document.getElementsByClassName("user-delete"); var ul = document.querySelector("#J_List"); var list = ul.querySelectorAll("li"); for (var i = 0; i < div.length; i++) { (function (i) { div[i].onclick = function () { list[i].remove(); console.log(i); } })(i); } } new Contact(); in (function (i) { div[i].onclick = function () { list[i].remove(); console.log(i); } })(i); I don't understand the meaning of this immediate execution function My code Contact.prototype.init = function () { let div = document.getElementsByClassName("user-delete"); let ul = document.querySelector("#J_List"); let list = ul.querySelectorAll("li"); for (let i in div) { div[i].onclick = function () { list[i].remove(); console.log(i); } } } new Contact(); Later I remembered that it was to avoid the problems caused by closures. Teacher Liao Xuefeng talked about this, but I didn’t remember it at the moment. For details, please see Liao Xuefeng’s closure. However, there was no problem running my code because there was no block-level scope at the time. But now I can use let to avoid this problem. So if i is declared using let, there is no need to execute the function immediately. And when writing code, you should avoid using var and use let instead. Another thing is to avoid using statements like for(let i =0;condition;++i) and try to use for...in... Some good habits should be developed. This concludes this article on how to avoid problems caused by closures with let in JavaScript. For more information on let closures in JavaScript, please search previous articles on 123WORDPRESS.COM or continue browsing the following related articles. I hope you will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Graphical introduction to the difference between := and = in MySQL
>>: Docker compose custom network to achieve fixed container IP address
Solution to forgetting MySQL password: [root@loca...
Table of contents Preface Features of Vue Native ...
Preface Since the types of the same fields in the...
To display the JSON data in a beautiful indented ...
Table of contents 1. Database Engine 1.1 View dat...
RGBA is a CSS color that can set color value and ...
In MySQL, the LOAD_FILE() function reads a file a...
This tutorial shares the process of manually inst...
Some friends, when learning about databases, acci...
The floating-point types supported in MySQL are F...
Result:Implementation code: <!DOCTYPE html>...
What is a table? Table is an Html table, a carrie...
Windows 10 now supports Linux subsystem, saying g...
Being a web designer is not easy. Not only do you...
This article example shares the specific code of ...