欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中l(wèi)et避免閉包造成問題

 更新時(shí)間:2021年07月23日 08:41:54   作者:[Object object]  
這篇文章主要介紹了JavaScript中l(wèi)et避免閉包造成問題,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

關(guān)于 let 避免閉包帶來的問題

利用面向?qū)ο笏枷胪瓿少I家信息刪除功能,每一條信息包含:

姓名
電話
電話號碼
省份

實(shí)現(xiàn)以下要求:
不能借用任何第三方庫,需要使用原生代碼實(shí)現(xiàn)。
結(jié)合給出的基本代碼結(jié)構(gòu),在下方2處code here補(bǔ)充代碼,完成買家信息的刪除功能,注意此頁面要在手機(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">序號</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();

后來想起來是為了避免閉包帶來的問題,這一段廖雪峰老師講過,但是一時(shí)沒有想起來,詳見 廖雪峰閉包
但是我的代碼運(yùn)行起來也是沒有任何問題的,因?yàn)楫?dāng)時(shí)沒有塊級作用域的說法,但是現(xiàn)在可以用 let 來避免這個(gè)問題。所以如果 i 是用 let 來聲明的話就可以不用立即執(zhí)行函數(shù)。并且寫代碼應(yīng)當(dāng)避免用 var,改用 let。還有一個(gè),避免使用 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)文章

  • php中and 和 &&出坑指南

    php中and 和 &&出坑指南

    在邏輯運(yùn)算符中,提到與和或,我們可能立刻想到的是&&、||,在php中還有and、or.然而and和or中有一個(gè)小小的坑,今天我們就來探討下php中and 和 &&
    2018-07-07
  • JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧與隊(duì)列

    JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧與隊(duì)列

    在面向?qū)ο蟮某绦蛟O(shè)計(jì)里,一般都提供了實(shí)現(xiàn)隊(duì)列(queue)和堆棧(stack)的方法,而對于JS來說,我們可以實(shí)現(xiàn)數(shù)組的相關(guān)操作,來實(shí)現(xiàn)隊(duì)列和堆棧的功能,看下面的相關(guān)介紹.
    2016-01-01
  • 怎樣在JavaScript里寫一個(gè)swing把數(shù)據(jù)插入數(shù)據(jù)庫

    怎樣在JavaScript里寫一個(gè)swing把數(shù)據(jù)插入數(shù)據(jù)庫

    在JavaScript里寫一個(gè)swing來實(shí)現(xiàn)確定取消,來決定是否執(zhí)行這個(gè)功能 控制把數(shù)據(jù)插入數(shù)據(jù)庫,接下來介紹實(shí)現(xiàn)方法
    2012-12-12
  • js parsefloat parseint 轉(zhuǎn)換函數(shù)

    js parsefloat parseint 轉(zhuǎn)換函數(shù)

    JavaScript提供了3個(gè)顯式的類型轉(zhuǎn)換函數(shù),分別是eval()、parseInt()和parseFloat()。
    2010-01-01
  • javascript中var與let、const的區(qū)別詳解

    javascript中var與let、const的區(qū)別詳解

    這篇文章主要介紹了javascript中var與let、const的區(qū)別詳解,需要的朋友可以參考下
    2022-12-12
  • 實(shí)現(xiàn)高性能JavaScript之執(zhí)行與加載

    實(shí)現(xiàn)高性能JavaScript之執(zhí)行與加載

    avaScript在瀏覽器中的性能,此問題因JavaScript的阻塞特征而復(fù)雜,也就是說JavaScript運(yùn)行時(shí)其他的事情不能被瀏覽器處理,事實(shí)上,大多數(shù)瀏覽器使用單進(jìn)程處理JavaScript運(yùn)行等多個(gè)任務(wù),而同一時(shí)間只能有一個(gè)任務(wù)被執(zhí)行。
    2016-01-01
  • js作用域及作用域鏈概念理解及使用

    js作用域及作用域鏈概念理解及使用

    作用域鏈?zhǔn)怯捎趈s的變量都是對象的屬性,而該對象可能又是其它對象的屬性,而所有的對象都是window對象的屬性,所以這些對象的關(guān)系可以看作是一條鏈
    2013-04-04
  • javascript將相對路徑轉(zhuǎn)絕對路徑示例

    javascript將相對路徑轉(zhuǎn)絕對路徑示例

    這篇文章主要介紹了javascript將相對路徑轉(zhuǎn)絕對路徑示例,這里介紹的其實(shí)本質(zhì)上是兩種方法,通過創(chuàng)建DOM或通過JavaScript計(jì)算,需要的朋友可以參考下
    2014-03-03
  • Javascript中arguments和arguments.callee的區(qū)別淺析

    Javascript中arguments和arguments.callee的區(qū)別淺析

    這篇文章主要介紹了Javascript中arguments和arguments.callee的區(qū)別淺析,本文用一個(gè)實(shí)例來理解它們的區(qū)別,需要的朋友可以參考下
    2015-04-04
  • javascript 實(shí)例詳解循環(huán)用法

    javascript 實(shí)例詳解循環(huán)用法

    假如您需要運(yùn)行代碼多次,且每次使用不同的值,那么循環(huán)(loop)相當(dāng)方便使用。本篇文章通過幾個(gè)實(shí)例來帶你掌握循環(huán)的用法
    2021-11-11

最新評論