1. 程式人生 > 程式設計 >JavaScript中let避免閉包造成問題

JavaScript中let避免閉包造成問題

關於 let 避免閉包帶來的問題

利用面向物件思想完成買家資訊刪除功能,每一條資訊包含:

姓名
電話
電話號碼
省份

實現以下要求:
不能借用任何第三方庫,需要使用原生程式碼實現。
結合給出的基本程式碼結構,在下方2處code here補充程式碼,完成買家資訊的刪除功能,注意此頁面要在手機上清晰顯示。

程式碼可以任意調整,例如和使用es6程式碼完成。

<!DOCTYPE html>
<html>
<head>
    <XvfOeS;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="n
ame">王二</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");
     http://www.cppcns.com   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);

這段立即執行函式沒看懂意義

我的程式碼

 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();

後來想起來是為了避免閉包帶來的問題,這一段廖雪峰老師講過,但是一時沒有想起來,詳見 廖雪峰閉包
但是我的程式碼執行起來也是沒有任何問題的,因為當時沒有塊級作用域的說法,但是現在可以用 let 來避免這個問題。所以如果 i 是用 let 來宣告的話就可以不用立即執行函式。並且寫程式碼應當避免用 var,改用 let。還有一個,避免使用 for(let i =0;condition;++i) 這種語句,儘量使用 for...in... 一些好的習慣要養成。

到此這篇關於中let避免閉包造成問題的文章就介紹到這了,更多相關Script中let閉包問題內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!