bodyタグ内にidノードを持つuタグを追加し、ulタグの下にliタグが5つあります。別の li タグをクリックしたときに li 添字をポップアップするにはどうすればよいですか?
1) まず、ul ノードを取得する必要があります var node = document.getElementsById('node')
2) ノードの下の子ノードを取得します node var list = node.children
**3) onclick イベントを子に追加しますループ内のノード (クロージャの問題が発生することに注意してください)。 for(var i=0;i
4) 出力 7 を分析します。i は var を使用してグローバル変数として宣言されているため、同じアドレスを指します。ループの実行後、i の値は 7 なので、各ループで出力される結果は 7 になります
これを解決するには 2 つの方法を使用します。1) ブロックレベルのスコープ変数を宣言し、渡すたびに let j = i を使用します。私は受け取ります 。
let j = i; list[i].onclick = function(){console.log(j)}
function メソッドでは、ブロックレベル変数 j が呼び出されます。この変数はガベージ コレクションされません。各 for ループは異なるアドレスを指すため、クリック イベントがトリガーされると、その添え字が正しく出力されます。 2) クロージャを使用して問題を解決します。
list[i].onclick = function(i){ return function(){console.log(i)}。 }
**クロージャの解釈
クロージャは、他の関数の内部変数を読み取ることができる関数です。 JavaScript 言語では、関数内のサブ関数のみがローカル変数を読み取ることができます。クロージャは、単純に「関数内で定義された関数」として理解できます。基本的に、クロージャは関数の内部と関数の外部を接続するブリッジです。
注: クロージャを使用すると、関数内の変数がメモリに保存され、大量のメモリを消費します。そのため、Web ページでパフォーマンスの問題が発生したり、IE ブラウザでメモリ リークが発生したりする可能性があるクロージャを悪用することはできません。 。 。最後の解決策は、関数を終了する前に未使用のローカル変数をすべて削除することです。
他の人の例を使用します。ご参考までに
var name = "this window"; var object = { name :"my object", getNameFunc:function () { return function () { return this.name; } } } alert(object.getNameFunc()());/弹出this window2 。此时this对象指向window对象 var object2 = { name: "my object", getNameFunc2: function () { var that = th is; return function () { return that.name; } } } alert(‘that’+object2.getNameFunc2()()); ///弹出my object。此时this对象指向object2对象
関連する推奨事項:
以上がJSクロージャの特徴分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。

Quartzタイマーを使用してタスクをスケジュールする場合、Quartzでタスク通知を事前に送信する方法、タスクの実行時間はCron式によって設定されます。今...

JavaScriptプログラミング、プロトタイプチェーンの関数パラメーターの理解と操作のJavaScriptのプロトタイプチェーンの関数のパラメーターを取得する方法は、一般的で重要なタスクです...

WeChatアプレットWeb-ViewでVue.jsを使用する動的スタイルの変位障害がvue.jsを使用している理由の分析...

複数のリンクの同時ゲットリクエストを作成し、結果を返すために順番に判断する方法は? TamperMonkeyスクリプトでは、複数のチェーンを使用する必要があることがよくあります...


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

メモ帳++7.3.1
使いやすく無料のコードエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ホットトピック



