JavaScript中l(wèi)et避免閉包造成問(wèn)題
關(guān)于 let 避免閉包帶來(lái)的問(wèn)題
利用面向?qū)ο笏枷胪瓿少I(mǎi)家信息刪除功能,每一條信息包含:
姓名
電話
電話號(hào)碼
省份
實(shí)現(xiàn)以下要求:
不能借用任何第三方庫(kù),需要使用原生代碼實(shí)現(xiàn)。
結(jié)合給出的基本代碼結(jié)構(gòu),在下方2處code here補(bǔ)充代碼,完成買(mǎi)家信息的刪除功能,注意此頁(yè)面要在手機(jī)上清晰顯示。
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">序號(hào)</div>
<div class="head name">姓名</div>
<div class="head sex">性別</div>
<div class="head tel">電話號(hào)碼</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的寫(xiě)法
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ù)沒(méi)看懂意義
我的代碼
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();
后來(lái)想起來(lái)是為了避免閉包帶來(lái)的問(wèn)題,這一段廖雪峰老師講過(guò),但是一時(shí)沒(méi)有想起來(lái),詳見(jiàn) 廖雪峰閉包
但是我的代碼運(yùn)行起來(lái)也是沒(méi)有任何問(wèn)題的,因?yàn)楫?dāng)時(shí)沒(méi)有塊級(jí)作用域的說(shuō)法,但是現(xiàn)在可以用 let 來(lái)避免這個(gè)問(wèn)題。所以如果 i 是用 let 來(lái)聲明的話就可以不用立即執(zhí)行函數(shù)。并且寫(xiě)代碼應(yīng)當(dāng)避免用 var,改用 let。還有一個(gè),避免使用 for(let i =0;condition;++i) 這種語(yǔ)句,盡量使用 for...in... 一些好的習(xí)慣要養(yǎng)成。
到此這篇關(guān)于JavaScript中l(wèi)et避免閉包造成問(wèn)題的文章就介紹到這了,更多相關(guān)JavaScript中l(wèi)et閉包問(wèn)題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Javascript中eval函數(shù)的使用方法與示例
JavaScript有許多小竅門(mén)來(lái)使編程更加容易。其中之一就是eval()函數(shù),這個(gè)函數(shù)可以把一個(gè)字符串當(dāng)作一個(gè)JavaScript表達(dá)式一樣去執(zhí)行它。以下是它的說(shuō)明2007-04-04
jQuery入門(mén)問(wèn)答 整理的幾個(gè)常見(jiàn)的初學(xué)者問(wèn)題
大家可能看到了,我已經(jīng)將過(guò)去寫(xiě)的兩篇jQuery的教程刪掉了,因?yàn)楦郊淮嬖诹说鹊葐?wèn)題,所以刪除了,從今天開(kāi)始我就寫(xiě)jQuery教程第二版了!希望大家能夠支持我!2010-02-02
JS 模態(tài)對(duì)話框和非模態(tài)對(duì)話框操作技巧匯總
模態(tài)窗口javascript 技巧包括傳值、打開(kāi)、刷新以及相關(guān)實(shí)例學(xué)習(xí),感興趣的朋友可以參考下哈2013-04-04
javascript中數(shù)組array及string的方法總結(jié)
本文結(jié)合自己的使用經(jīng)驗(yàn),給大家總結(jié)了javascript中數(shù)組array及string的使用方法,這里推薦給有需要的小伙伴。2014-11-11
javascript Function函數(shù)理解與實(shí)戰(zhàn)
小編給大家?guī)?lái)一片關(guān)于javascript的基礎(chǔ)教學(xué)內(nèi)容,關(guān)于Function函數(shù)的訓(xùn)練與理解,一起學(xué)習(xí)下吧。2017-12-12
Javascript全局變量var與不var的區(qū)別深入解析
這篇文章主要介紹了Javascript全局變量var與不var的區(qū)別。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12

