JavaScriptが設定されていない

王林
王林オリジナル
2023-05-16 09:52:37620ブラウズ

JavaScript は、Web 開発で広く使用されているプログラミング言語です。 Web サイトに機能を追加する場合、JavaScript を使用して Web ページをよりインタラクティブで動的にします。 Web 開発では、多くの場合、いくつかのタスクを達成するためにいくつかの関数をセットアップする必要があります。ただし、設定した機能を解除する必要がある場合があります。この記事ではJavaScriptでset関数を解除する方法を紹介します。

1. イベント リスナーのキャンセル

Web 開発では、ユーザーが要素を操作するときに何らかの操作を実行するために要素にイベント リスナーを追加する必要がよくあります。たとえば、クリック イベント リスナーをボタンに追加して、ユーザーがボタンをクリックしたときにコードが起動されるようにすることができます。ただし、場合によっては、追加されたイベント リスナーをキャンセルする必要があります。

イベント リスナーのキャンセルは、removeEventListener() メソッドを通じて実行できます。このメソッドでは、イベント タイプとキャンセルする関数という 2 つのパラメータを渡す必要があります。たとえば、次のコードはクリック イベント リスナーをボタンに追加します。

const button = document.getElementById('myButton');
button.addEventListener('click', myFunction);

このイベント リスナーをキャンセルするには、次のコードを使用できます。

button.removeEventListener('click', myFunction);

これにより、以前に追加されたクリックが削除されます。イベントリスナー。

2. タイマーをキャンセルする

Web 開発では、一部のコードを 2 回おきに実行したり、一定期間後に一部のコードを実行したりするなど、一部のコードを実行するためにタイマーを使用する必要があることがよくあります。 . . JavaScript を使用すると、setTimeout() 関数と setInterval() 関数を使用してタイマーを実装できます。

setTimeout() 関数は、指定された時間後にタスクを実行するために使用され、setInterval() 関数は、指定された時間間隔でタスクを実行するために使用されます。ただし、場合によっては、タスクの繰り返しを避けるために、設定されたタイマーをキャンセルする必要があります。

タイマーのキャンセルは、clearTimeout() 関数および clearInterval() 関数を通じて実行できます。これらの関数はすべて、キャンセルするタイマー ID であるパラメーターを渡す必要があります。たとえば、次のコードは setTimeout() 関数を使用してタイマーを設定します。

const myTimeout = setTimeout(myFunction, 3000);

このタイマーをキャンセルするには、次のコードを使用できます。

clearTimeout(myTimeout);

setInterval() を使用した場合before タイマーが関数によって設定されている場合、clearInterval() 関数を使用してタイマーをキャンセルする必要があります。

3. デフォルトの動作をキャンセルする

Web 開発では、デフォルトの動作とは、特定の状況下でブラウザが行う動作を指します。たとえば、リンクをクリックすると、ブラウザはリンクが指すページにジャンプしようとし、フォームを送信すると、ブラウザはフォーム データを処理できるようにフォームをサーバーに送信しようとします。場合によっては、これらのデフォルトの動作をキャンセルする必要があります。

デフォルトの動作をキャンセルするには、preventDefault() メソッドを使用します。このメソッドはイベント ハンドラー内で呼び出す必要があり、他のコードが実行される前にデフォルトの動作をキャンセルできるように、イベント ハンドラーの先頭で呼び出す必要があります。たとえば、次のコードはクリック イベント リスナーをリンクに追加し、ブラウザがリンクが指すページにジャンプするのを防ぎます:

const link = document.getElementById('myLink');
link.addEventListener('click', function(event) {
  event.preventDefault();
  // 做其他事情,例如显示一个提示框
});

4. Unbubbling

Web 開発では、イベント伝播はバブリングとキャプチャの 2 つの形式に分けられます。バブリングでは、イベントは最初に最も特定的な要素 (ボタンなど) でトリガーされ、次に最上位の要素に到達するまで上方に伝播します。キャプチャは最上位の要素から開始され、最も具体的な要素に到達するまで下位に進みます。

他のコードでのイベントの処理を避けるために、イベントの伝播を防止する必要がある場合があります。イベントバブリングのキャンセルは、stopPropagation() メソッドを使用して実現できます。このメソッドはイベント ハンドラー内で呼び出す必要があり、他のコードが実行される前に呼び出す必要があります。たとえば、次のコードは、ボタンとそれを含む div 要素の両方にクリック イベント リスナーを追加します。ボタンがクリックされると、ボタンのクリック イベントがトリガーされますが、それを含む div 要素にはバブルされません:

const button = document.getElementById('myButton');
const div = document.getElementById('myDiv');
button.addEventListener('click', function(event) {
  // 处理按钮单击事件
  event.stopPropagation();
});
div.addEventListener('click', function(event) {
  // 处理div单击事件
});

このコードは、ボタンのクリック イベント ハンドラーで stopPropagation を呼び出すことで機能します。イベントが div 要素までバブリングされます。

概要

JavaScript では、設定解除の機能をさまざまな方法で実装できます。イベント リスナーをキャンセルするには、removeEventListener() メソッドを使用します。タイマーをキャンセルするには、clearTimeout() 関数と clearInterval() 関数を使用します。デフォルトの動作をキャンセルするには、preventDefault() メソッドを使用します。また、キャンセルするには、stopPropagation() メソッドを使用します。イベントの盛り上がり。これらの関数を実装するときは、コードが必要な操作を正しく実行できるように、適切なタイミングで関数を使用することに注意する必要があります。

以上がJavaScriptが設定されていないの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。