- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > web開(kāi)發(fā) > JavaScript >
- JavaScript中let避免閉包造成問(wèn)題
利用面向對象思想完成買(mǎi)家信息刪除功能,每一條信息包含:
姓名
電話(huà)
電話(huà)號碼
省份
實(shí)現以下要求:
不能借用任何第三方庫,需要使用原生代碼實(shí)現。
結合給出的基本代碼結構,在下方2處code here補充代碼,完成買(mǎi)家信息的刪除功能,注意此頁(yè)面要在手機上清晰顯示。
js代碼可以任意調整,例如和使用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">電話(huà)號碼</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);
這段立即執行函數沒(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) 廖雪峰閉包
但是我的代碼運行起來(lái)也是沒(méi)有任何問(wèn)題的,因為當時(shí)沒(méi)有塊級作用域的說(shuō)法,但是現在可以用 let 來(lái)避免這個(gè)問(wèn)題。所以如果 i 是用 let 來(lái)聲明的話(huà)就可以不用立即執行函數。并且寫(xiě)代碼應當避免用 var,改用 let。還有一個(gè),避免使用 for(let i =0;condition;++i) 這種語(yǔ)句,盡量使用 for...in... 一些好的習慣要養成。
到此這篇關(guān)于JavaScript中let避免閉包造成問(wèn)題的文章就介紹到這了,更多相關(guān)JavaScript中let閉包問(wèn)題內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站