ホームページ ウェブフロントエンド jsチュートリアル JavaScript イベント学習 第 4 章 従来のイベント登録モデル_JavaScript スキル

JavaScript イベント学習 第 4 章 従来のイベント登録モデル_JavaScript スキル

May 16, 2016 pm 06:35 PM
event

最も古い JavaScript ブラウザでのイベントの登録は、インライン モードでのみ可能です。 DHTML はページの操作方法を根本的に変えるため、イベント登録は拡張可能で適応性が高い必要があります。したがって、対応するイベント モデルが存在する必要があります。 Netscape は第 3 世代のブラウザから始まり、IE は第 4 世代のブラウザから始まりました。
Netscape 3 はこの新しいイベント登録モデルのサポートを開始したため、ブラウザ戦争以前は事実上の標準でした。したがって、Microsoft は、Netscape イベント処理モデルを使用するインターネット上の無数のページについて、互換性に関して最後に譲歩する必要がありました。
これら 2 つのブラウザ、実際にはすべてのブラウザが次のコードをサポートしています:

コードをコピー コードは次のとおりです:

element.onclick = doSomething;

これはイベントを登録する最良の方法です。ユーザーがこの HTML 要素をクリックするたびに、doSomething() が実行されます。これは、ブラウザー間でイベントを登録する唯一の最善の方法であり、このモデルとその制限について深く理解することが重要です。
正式な標準がないため、私はこれを仮に伝統的なイベント登録モデルと呼んでいます。同時に、w3c もイベント登録を標準化し、Microsoft もアドバンスト モードを開始しましたが、従来のモードでも引き続き問題なく実行できます。


Advanced Event Register
Netscape 3/IE 4 以降、JavaScript は要素上の一連のイベントの属性を認識できるようになりました。ほとんどの HTML 要素には、onclick、onmouseover、onkeypress などの属性があります。これらの要素がどのような属性を持つか、どの要素がどのイベントをサポートするかはすべてブラウザによって異なります。
これらのプロパティ自体も新しいものではありません。最も古い JavaScript ブラウザにはすでに存在しています。
コードをコピー コードは次のとおりです:


ここの A タグには onclick パラメータがあり、JavaScript では A 要素の属性になります。古いブラウザのイベント ハンドラーは、ページのソース コード内の要素にパラメーターを設定することによってのみ登録できました。このスクリプトをすべての A タグで実行したい場合は、すべてのリンクに onclick イベントを追加する必要があります。
従来のイベント登録モデルの登場により、これらの onclick、onmouseover、またはその他の HTML 要素のイベント処理を JavaScript を通じて登録できるようになりました。 HTML に一切触れずに、イベント ハンドラーを追加、変更、削除できるようになりました。 DOM 経由で HTML 要素にアクセスする場合、次のようなコードを記述できます:
コードをコピー コードは次のとおりです:

element.onclick = doSomething;


ここで、サンプル関数 doSomething() が element 要素の onclick 属性に登録され、ユーザーがこの要素をクリックすると関数が実行されます。イベント名は小文字にする必要があることに注意してください。
このイベント ハンドラーを削除するには、クリック イベントを空のままにします:
コードをコピーします コードは次のとおりです:

element.onclick = null;

イベント ハンドラーは通常の JavaScript 関数と同じです。イベントが発生していないときでも、彼はそれを実行できます。次のように書くと:
コードをコピー コードは次のとおりです:

element.onclick ()

すると doSomething も実行されます。ただし、何をすべきかわからない関数やエラーが発生する関数の場合は、実際のイベントは発生しません。したがって、これはイベント ハンドラーを実行する方法としてはほとんど使用されません。
Microsoft の IE5.5 以降のバージョンにも、同じことを実現する fireEvent() メソッドがあります。次のように使用します:
コードをコピー コードは次のとおりです:

element.fireEvent(' onclick')


括弧なし
イベント ハンドラーを登録するときに括弧は使用できないことに注意してください。 onclickメソッドは別の関数に設定されます。このように書くと
コードをコピーします コードは次のとおりです。

element.onclick = doSomething();


すると、この関数が実行され、その結果が onclick に登録されます。これは私たちが期待しているものではなく、イベントが発生したときに関数を実行したいだけです。さらに、この関数はイベントの発生時に実行されるように記述されています。実行が関連付けられていないと、重大な混乱やエラーが発生します。
そこで、イベント ハンドラー内の doSomething() メソッド全体をコピーします。イベントの実行時にこの関数を実行したいだけです。


this
JavaScript では、this キーワードは通常、関数の所有者を指します。これがイベントが発生した HTML 要素を指している場合は、すべて問題なく、多くのことを簡単に行うことができます。
残念ながら、これは非常に強力ではありますが、どのように機能するかを正確に知らないと使用するのがまだ困難です。これについては他の場所で詳しく説明しましたが、ここでは従来のモードでの概要を説明します。
従来のモードでは、これは次のように動作します。これはインライン モードとは若干異なることに注意してください。 this キーワードは HTML パラメータではなく関数内にあります。この違いについては後で別途説明します。
コードをコピーします コードは次のとおりです。

element.onclick = doSomething; another_element.onclick = doSomething;
function doSomething() {
this.style.backgroundColor = '#cc0000';
}

doSomething() を任意の HTML として登録した場合要素のクリック イベントが発生すると、ユーザーがその要素をクリックすると、要素に背景が表示されます。


匿名関数
マウスが上を通過するとすべての div の背景色を変更し、マウスが離れると背景色に戻るようにしたいとします。これを正しく使用するには、次のように記述できます:

コードをコピーします コードは次のとおりです:
var x = document.getElementsByTagName('DIV');
for (var i=0;ix[i].onmouseover = over;
実行します、問題ありません。ただし、over() と out() は比較的単純であるため、より洗練された匿名関数メソッドを使用して次のように記述することができます。 > コードは次のとおりです:

とにかく、onmouseoverとonmouseoutの両方が関数を取得します。 over() と out() をコピーするよりも、イベントが登録されるスクリプト上で直接イベント ハンドラーを定義する方が良いでしょう。これらの関数には名前がないため、匿名関数となります。
イベント ハンドラーを登録するこれら 2 つの方法は基本的に同じですが、唯一の違いは、2 番目の方法のコードが少ないことです。私は匿名関数がとても好きで、単純なイベント ハンドラーを登録するときに匿名関数を使用します。


問題
小さな問題は、従来のモードでは onclick 属性に 1 つの関数しか含めることができないことです。問題は、1 つのイベントに対して複数のイベント ハンドラーを登録する場合に発生します。
たとえば、ドラッグ可能なモジュールを作成したとします。このモジュールは onclick イベント ハンドラーに登録されているため、クリックするとドラッグを開始できます。また、ユーザーのクリックを追跡し、onunload 中にサーバーに情報を送信して、ページがどのように使用されているかを知ることができるモジュールも作成しました。このモジュールは、要素に onclick イベントを登録する必要もあります。
このようになります:




コードをコピーします


コードは次のとおりです:

要素.onclick = startDragDrop;
ここでエラーが発生します。 2 番目の登録プロシージャは最初の登録プロシージャを上書きするため、ユーザーが要素をクリックしたときに spyOnUser() のみが実行されます。
解決策は、2 つのメソッドを含むメソッドを登録することです:
コードをコピーします コードは次のとおりです:

element.onclick = function () {
startDragDrop()
spyOnUser()
}



柔軟な登録
しかし、Web サイトのすべてのページで 2 つのモジュールを使用しないと仮定しましょう。まだこのように書く場合:
コードをコピー コードは次のとおりです:

要素。 onclick = function () {
startDragDrop();
spyOnUser()
}

関数の 1 つが未定義であるため、エラー メッセージが表示されます。したがって、イベントを登録するときは特に注意してください。 startDragDrop() がすでに登録されている可能性があるときに spyOnUser() を登録したい場合は、次のように記述できます:
コードをコピー コードは次のとおりです:

var old = (element.onclick) ? element.onclick : function () {};
element.onclick = function () {
old ();
spyOnUser()
};

まず、変数 old を定義します。要素に既に onclick イベント ハンドラーがある場合は、old に格納します。ない場合は、old を空の関数に設定します。ここで、div の新しいイベント ハンドラーを登録する必要があります。次に、プログラムは最初に old() を実行し、次に spyOnUser() を実行します。これで、新しいイベント ハンドラーが要素に追加され、以前に登録されたイベント ハンドラー (存在する場合) も含まれます。
最後の質問: イベント ハンドラーの 1 つを削除したい場合はどうすればよいですか?今はわかりません。何らかの方法で element.onclick() を編集する必要がありますが、これについてはまだ調べていません。
その他のモード
従来のモードは非常にシンプルで使いやすいことがわかりましたが、イベントに複数のプログラムを追加する場合の解決策はまだ見にくいです。 W3C のイベント ハンドラーは、この問題をうまく解決します。
続き
学習を続けたい場合は、次の章をお読みください。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? 独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか? Mar 18, 2025 pm 03:12 PM

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか? Mar 18, 2025 pm 03:14 PM

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:16 PM

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? ソースマップを使用して、マイナイドJavaScriptコードをデバッグするにはどうすればよいですか? Mar 18, 2025 pm 03:17 PM

この記事では、ソースマップを使用して、元のコードにマッピングすることにより、Minified JavaScriptをデバッグする方法について説明します。ソースマップの有効化、ブレークポイントの設定、Chrome DevtoolsやWebpackなどのツールの使用について説明します。

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

See all articles