JavaScript のクロージャによって発生する問題を回避する

JavaScript のクロージャによって発生する問題を回避する

閉鎖による問題を回避するためのletについて

オブジェクト指向の考え方を使用して、購入者情報の削除機能を完成させます。各情報には次のものが含まれます。

名前 電話番号 都道府県

次の要件を実装します。
サードパーティのライブラリは使用できず、ネイティブ コードを使用する必要があります。
与えられた基本的なコード構造と組み合わせて、ここのコードの下の 2 つの場所にコードを追加して、購入者情報の削除機能を完成させます。このページは携帯電話で明確に表示する必要があることに注意してください。

js コードを任意に調整し、例えば es6 コードを使用して完成させることができます。

<!DOCTYPE html>
<html>
<ヘッド>
    <メタ文字セット="utf-8">
    <!--ここにコード-->
    <title>デモ</title>
    <スタイル>
        * {
            パディング: 0;
            マージン: 0;
        }

        .head、li div {
            表示: インラインブロック;
            幅: 70ピクセル;
            テキスト配置: 中央;
        }

        li .id、li .sex、.id、.sex {
            幅: 15px;
        }

        li .name, .name {
            幅: 40px;
        }

        li .tel、.tel {
            幅: 90ピクセル;
        }

        li .del、.del {
            幅: 15px;
        }

        ul {
            リストスタイル: なし;
        }

        .ユーザー削除{
            カーソル: ポインタ;
        }

    </スタイル>
</head>

<本文>
<div id="J_コンテナ">
    <div class="レコードヘッド">
        <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_リスト">
        <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>

<スクリプト>
    // ここでも ES6 を使用できます function Contact() {
        これを初期化します。
    }

    // ここにコードを記述
</スクリプト>
</本文>
</html>

コード1

<meta name="viewport" content="width = デバイス幅、初期スケール=1">

code2 (他の人のコード)

 Contact.prototype.init = 関数(){
        console.log("テスト");
        var div = document.getElementsByClassName("user-delete");
        var ul = document.querySelector("#J_List");
        var list = ul.querySelectorAll("li");

        (var i = 0; i < div.length; i++) の場合 {
            (関数 (i) {
                div[i].onclick = 関数(){
                    リスト[i].remove();
                    コンソールにログ出力します。
                }
            })(私);
        }
    }

    新しい連絡先();

 (関数 (i) {
                div[i].onclick = 関数(){
                    リスト[i].remove();
                    コンソールにログ出力します。
                }
            })(私);

この即時実行機能の意味が分かりません

私のコード

 Contact.prototype.init = 関数(){
        div を document.getElementsByClassName("user-delete"); に設定します。
        ul = document.querySelector("#J_List"); とします。
        リストを ul.querySelectorAll("li") にします。

        for (let i in div) {
            div[i].onclick = 関数(){
                リスト[i].remove();
                コンソールにログ出力します。
            }
        }
    }

    新しい連絡先();

後で思い出しましたが、これはクロージャによって引き起こされる問題を回避するためでした。Liao Xuefeng先生がこのことについて話されていましたが、その時は思い出せませんでした。詳しくは、Liao Xuefengのクロージャを参照してください。ただし、当時はブロックレベルのスコープがなかったため、コードを実行しても問題はありませんでした。しかし、今ではletを使用してこの問題を回避できます。したがって、i が let を使用して宣言されている場合、関数をすぐに実行する必要はありません。また、コードを書くときは、var の使用を避け、代わりに let を使用する必要があります。もう 1 つは、for(let i =0;condition;++i) のようなステートメントの使用を避け、for...in... を使用するようにすることです。良い習慣を身につける必要があります。

これで、JavaScript の let クロージャによって発生する問題を回避する方法についての記事は終了です。JavaScript の let クロージャの詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScript における関数のネスト
  • 1つの記事でJavaScriptのクロージャ関数について学ぶ
  • JavaScript クロージャの説明
  • Javascript のスコープとクロージャの詳細
  • JS の難しさ 同期と非同期、スコープとクロージャ、プロトタイプとプロトタイプ チェーンの詳細な説明
  • JavaScript のクロージャの問題の詳細な説明
  • JavaScript 関数の使用方法の詳細な説明 [関数の定義、パラメータ、バインディング、スコープ、クロージャなど]
  • js における関数のネストとクロージャの詳細

<<:  MySQL における := と = の違いをグラフィカルに紹介

>>:  Docker は固定コンテナ IP アドレスを実現するためにカスタム ネットワークを作成します。

推薦する

HTML thead タグの定義と使用法の詳細な紹介

コードをコピーコードは次のとおりです。 <thead> <!– 最初の 2 行をヘ...

Javascript デザインパターン プロトタイプ モードの詳細

目次1. プロトタイプモード例1例2例3 2. オブザーバーパターン1. プロトタイプモードプロトタ...

初心者でもjsのtypeofとinstanceofの違いを理解できます

目次1. 型2. インスタンス3. 違い1. 型typeof 演算子は、評価されていないオペランドの...

HTML ベース URL タグ

その機能はグローバル スタイルを設定することです。その後の相対パスはこれに基づきます: <im...

CentOS 7 ブートカーネルの切り替えとブートモードの切り替えの説明

Centos7 スイッチブートカーネル注: 必要に応じて、最初にyum update -yを実行して...

MySQL 8.0.13 で日付を 0000-00-00 00:00:00 に設定すると発生する問題を解決する

データベース操作を学び始めたばかりです。今日、データを保存していたところ、エラーが発生していることに...

よくある CSS エラーと解決策

コードをコピーコードは次のとおりです。 IE6 と FF の違い: background:orang...

Nginx リバース プロキシから go-fastdfs へのケースの説明

背景go-fastdfs は、http プロトコルをサポートする分散ファイルシステムです。一般的なプ...

MySQL コマンドを使用してインデックスを作成、削除、およびクエリする方法の紹介

MySQL データベース テーブルでは、インデックスを作成、表示、再構築、削除できるため、クエリ速度...

JSはフロントエンドのページング効果を実現します

この記事の例では、フロントエンドのページング効果を実現するためのJSの具体的なコードを参考までに共有...

Linux 最速のテキスト検索ツール ripgrep (grep の最良の代替)

序文テキスト検索ツールといえば、Linux で最も便利でよく使われるツールの 1 つである grep...

JavaScript で配列の変更を監視する方法

序文以前、defineProperty を紹介したとき、オブジェクトの変更のみを監視でき、配列の変更...

jQueryはシンプルなコメントエリアを実装します

この記事では、参考までに、簡単なコメントエリアを実装するためのjQueryの具体的なコードを紹介しま...

手書きの Vue2.0 データハイジャックの例

目次1: webpackをビルドする2. データハイジャック3: まとめ1: webpackをビルド...

中国における中国語ドメイン名の人気は新たなクライマックスを迎えた

<br />外交部などの中央政府機関、各レベルの地方政府、その他の国家機関や部門が率先し...