js遅延関数の考え方の紹介

不言
リリース: 2020-02-27 14:31:42
転載
2645 人が閲覧しました

遅延関数は、js 関数型プログラミングのもう 1 つの応用です。遅延関数とは、関数が初めて呼び出されたときにのみ関数実行の分岐が実行されることを意味します。この記事では、js 遅延関数のアイデアを皆さんに紹介します。 . 皆様のお役に立てれば幸いです。

js遅延関数の考え方の紹介

vue、react、その他のフレームワークが広く使用される前は、dom を操作してコードを記述するために jQuery またはネイティブ js を使用する必要がありました。イベントバインディングにネイティブ js を使用する場合、DOM2 レベルのバインディングイベントメソッドを適用できます。 :Element.addEventListener() ですが、互換性のために、

Element.attachEvent() とも呼ばれます。したがって、それをメソッドにカプセル化する必要があります:

function emit(element, type, func) {
    if (element.addEventListener) {
        element.addEventListener(type, func, false);
    } else if (element.attachEvent) {
        element.attachEvent('on' + type, func);
    } else { //如果不支持DOM2级事件
        element['on' + type] = func;
    }
}
ログイン後にコピー

この時点で、要素が 1 つの動作を通じて複数のクリック イベントを追加する必要がある場合、たとえば:

emit(div, 'click', fn1);
emit(div, 'click', fn2);
ログイン後にコピー

初めて fn1 イベントを div にバインドするとき、ブラウザはどのバインディングメソッドが実行されるかをすでに知っていますか? バインディング fn2 を実行するとき、再度判断する必要はなく、コードを変更できます:

function emit(element, type, func) {
    if (element.addEventListener) {
        emit = function (element, type, func) {
            element.addEventListener(type, func, false);
        };
    } else if (element.attachEvent) {
        emit = function (element, type, func) {
            element.attachEvent('on' + type, func);
        };
    } else {
        emit = function (element, type, func) {
            element['on' + type] = func;
        };
    }
    emit(element, type, func);
}
ログイン後にコピー

つまり、最初の判断を行った後、関数を再定義します。そのため、後でバインドするときに判断を行う必要がなくなります。クロージャは作成されますが、将来同じ判断を複数回行うよりも優れています。

これは関数の怠惰なアイデアです。同じ判断を行うには、一度だけ行う必要があります。

この記事は js チュートリアル コラムからのものです。学習へようこそ!

以上がjs遅延関数の考え方の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
js
ソース:cnblogs.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
ノード Js + JS 入力 = document.getElementById
から 1970-01-01 08:00:00
0
0
0
js addClassが機能しない
から 1970-01-01 08:00:00
0
0
0
javascript - jsコードをPythonに変換
から 1970-01-01 08:00:00
0
0
0
jsファイルのコードが見つかりません
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート