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 アドレスを実現するためにカスタム ネットワークを作成します。

推薦する

JavaScript を使用して二分探索木を実装する方法

コンピュータ サイエンスで最も一般的に使用され、議論されているデータ構造の 1 つは、二分探索木です...

Linux における $ 記号の基本的な使い方のまとめ

Linuxバージョン: CentOS 7 [root@azfdbdfsdf230lqdg1ba91 ...

WeChatアプレット+mqtt、esp8266温度と湿度の読み取り実装方法

まず、 esp8266 は mqtt を通じてメッセージを公開し、WeChat アプレットは mqt...

Git サーバーを使用してデバッグ ブランチを表示し、修正する方法を 1 日 1 分で学習します。

デバッグブランチプロジェクトの通常の開発中に、以前にリリースされたバージョンにバグがある場合がありま...

Vue テンプレートのコンパイルの詳細

目次1. 解析する1.1 傍受のルール1.2 傍受プロセス部分1.3 パーサーの概要2. 最適化する...

Docker で lnmp をデプロイする詳細な手順

目次Centosイメージを取得するCentos ベースの nginx コンテナを生成するCentos...

CSS を使用して複数の方法で下揃えを実装するサンプル コード

会社のビジネス要件により、次の図の赤い領域の効果を達成する必要があります。 効果の説明: 1. 赤い...

Linux で Oracle データベースをバックアップするためのスケジュールされたタスクの設定に関するチュートリアル

1. データベースの文字セットを確認するデータベースの文字セットは、Linux で設定された環境変数...

MySQLデータベース最適化技術の簡単な紹介

成熟したデータベース アーキテクチャは、最初から高可用性、高スケーラビリティなどの機能を備えて設計さ...

Dockerコンテナの操作手順の概要と詳細説明

1. コンテナを作成して実行するdocker run -it --rm centos:latest ...

MySQL 8.0 の非表示列に対する基本操作

目次01 非表示の列を作成する02 非表示の列に対する基本操作03 非表示の列メタデータ04 主キー...

Linuxネットワーク設定の基本操作コマンドを詳しく解説

目次ネットワーク構成を表示するネットワークインターフェース情報を表示する---ifconfigルーテ...

CSS でよく発生する問題の整理 (ロゴのハッキング/コンテナの固定/画像の垂直方向の中央揃え)

1. IEブラウザモードハックロゴ1. CSSハックロゴコードをコピーコードは次のとおりです。 ie...

VMware Workstation のインストール Linux (Ubuntu) システム

システムをコンピューターにインストールする方法がわからない場合は、Linux を学習したい場合は、仮...

MySQL 5.7.18 バージョンの無料インストール構成チュートリアル

MySQLはインストール版と無料インストール版に分かれていますインストール版の拡張子はmsi、無料イ...