国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

JavaScript中let避免閉包造成問(wèn)題

發(fā)布時(shí)間:2021-08-17 12:16 來(lái)源: 閱讀:0 作者:[Object object] 欄目: JavaScript 歡迎投稿:712375056

關(guān)于 let 避免閉包帶來(lái)的問(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í)歡迎投稿傳遞力量。

国产一精品一AV一免费爽爽| 成人免费无码大片A毛片抽搐| 国产又黄又爽又刺激的免费网址| 久久熟妇人妻午夜寂寞影院| 成人高潮视频在线观看| 无码精品久久久久久人妻中字|