JavaScript中l(wèi)et避免閉包造成問題
關(guān)于 let 避免閉包帶來的問題
利用面向?qū)ο笏枷胪瓿少I家信息刪除功能,每一條信息包含:
姓名
電話
電話號碼
省份
實現(xiàn)以下要求:
不能借用任何第三方庫,需要使用原生代碼實現(xiàn)。
結(jié)合給出的基本代碼結(jié)構(gòu),在下方2處code here補充代碼,完成買家信息的刪除功能,注意此頁面要在手機上清晰顯示。
js代碼可以任意調(diào)整,例如和使用es6代碼完成。
<!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">序號</div>
<div class="head name">姓名</div>
<div class="head sex">性別</div>
<div class="head tel">電話號碼</div>
<div class="head province">省份</div>
<div class="head">操作</div>
</div>
<ul id="J_List">
<li>
<div class="id">1</div>
<div class="name">張三</div>
<div class="sex">男</div>
<div class="tel">13788888888</div>
<div class="province">浙江</div>
<div class="user-delete">刪除</div>
</li>
<li>
<div class="id">2</div>
<div class="name">李四</div>
<div class="sex">女</div>
<div class="tel">13788887777</div>
<div class="province">四川</div>
<div class="user-delete">刪除</div>
</li>
<li>
<div class="id">3</div>
<div class="name">王二</div>
<div class="sex">男</div>
<div class="tel">13788889999</div>
<div class="province">廣東</div>
<div class="user-delete">刪除</div>
</li>
</ul>
</div>
<script>
// 此處也可換成ES6的寫法
function Contact() {
this.init();
}
// your code here
</script>
</body>
</html>
code1
<meta name="viewport" content="width = device-width,initial-scale=1">
code2 ( 別人的代碼 )
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();
其中
(function (i) {
div[i].onclick = function () {
list[i].remove();
console.log(i);
}
})(i);
這段立即執(zhí)行函數(shù)沒看懂意義
我的代碼
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();
后來想起來是為了避免閉包帶來的問題,這一段廖雪峰老師講過,但是一時沒有想起來,詳見 廖雪峰閉包
但是我的代碼運行起來也是沒有任何問題的,因為當(dāng)時沒有塊級作用域的說法,但是現(xiàn)在可以用 let 來避免這個問題。所以如果 i 是用 let 來聲明的話就可以不用立即執(zhí)行函數(shù)。并且寫代碼應(yīng)當(dāng)避免用 var,改用 let。還有一個,避免使用 for(let i =0;condition;++i) 這種語句,盡量使用 for...in... 一些好的習(xí)慣要養(yǎng)成。
到此這篇關(guān)于JavaScript中l(wèi)et避免閉包造成問題的文章就介紹到這了,更多相關(guān)JavaScript中l(wèi)et閉包問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧與隊列
在面向?qū)ο蟮某绦蛟O(shè)計里,一般都提供了實現(xiàn)隊列(queue)和堆棧(stack)的方法,而對于JS來說,我們可以實現(xiàn)數(shù)組的相關(guān)操作,來實現(xiàn)隊列和堆棧的功能,看下面的相關(guān)介紹.2016-01-01
怎樣在JavaScript里寫一個swing把數(shù)據(jù)插入數(shù)據(jù)庫
在JavaScript里寫一個swing來實現(xiàn)確定取消,來決定是否執(zhí)行這個功能 控制把數(shù)據(jù)插入數(shù)據(jù)庫,接下來介紹實現(xiàn)方法2012-12-12
js parsefloat parseint 轉(zhuǎn)換函數(shù)
JavaScript提供了3個顯式的類型轉(zhuǎn)換函數(shù),分別是eval()、parseInt()和parseFloat()。2010-01-01
javascript中var與let、const的區(qū)別詳解
這篇文章主要介紹了javascript中var與let、const的區(qū)別詳解,需要的朋友可以參考下2022-12-12
實現(xiàn)高性能JavaScript之執(zhí)行與加載
avaScript在瀏覽器中的性能,此問題因JavaScript的阻塞特征而復(fù)雜,也就是說JavaScript運行時其他的事情不能被瀏覽器處理,事實上,大多數(shù)瀏覽器使用單進程處理JavaScript運行等多個任務(wù),而同一時間只能有一個任務(wù)被執(zhí)行。2016-01-01
Javascript中arguments和arguments.callee的區(qū)別淺析
這篇文章主要介紹了Javascript中arguments和arguments.callee的區(qū)別淺析,本文用一個實例來理解它們的區(qū)別,需要的朋友可以參考下2015-04-04

