关于 let 避免闭包带来的问题

今天晚上做了一下阿里校园招聘在线模拟笔试,有一道编程题是下面这样的

利用面向对象思想完成买家信息删除功能,每一条信息包含:

姓名
电话
电话号码
省份

实现以下要求:
不能借用任何第三方库,需要使用原生代码实现。
结合给出的基本代码结构,在下方2处code here补充代码,完成买家信息的删除功能,注意此页面要在手机上清晰显示。

js代码可以任意调整,例如和使用es6代码完成。


<html>
<head>
    <meta charset="utf-8">
    
    <title>demotitle>
    <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">1div>
            <div class="name">张三div>
            <div class="sex">div>
            <div class="tel">13788888888div>
            <div class="province">浙江div>
            <div class="user-delete">删除div>
        li>
        <li>
            <div class="id">2div>
            <div class="name">李四div>
            <div class="sex">div>
            <div class="tel">13788887777div>
            <div class="province">四川div>
            <div class="user-delete">删除div>
        li>
        <li>
            <div class="id">3div>
            <div class="name">王二div>
            <div class="sex">div>
            <div class="tel">13788889999div>
            <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

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

这段立即执行函数没看懂意义

我的代码

 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... 一些好的习惯要养成。

你可能感兴趣的:(javascript)