ホームページ >ウェブフロントエンド >jsチュートリアル >Click() はリンク ナビゲーションのシミュレートに使用できますか?
Click() を使用してリンク ナビゲーションをエミュレートできますか?
JavaScript タイマーを使用する場合、多くの開発者は jQuery の click() 関数を利用して、リンクのクリックをエミュレートし、設定された時間間隔後に別のページに移動します。 click() メソッドは意図したとおりに動作しますが、いくつかの予期しない動作が観察され、その機能について疑問が生じています。
ブラウザの動作
イベント ハンドラーがbinding() または click() を使用して リンクに割り当てられていない場合、 click() を呼び出しても効果がないようです。ブラウザはリンクをたどらず、対象のページを読み込みません。
ただし、イベント ハンドラーが最初に確立されると、ハンドラーにコードが含まれていない場合でも、click() は期待どおりに機能します。
$('a').click(function(){return true;}).click();
この場合、ユーザーが手動でリンクをクリックしたかのように新しいページが読み込まれます。
説明
当初、観察された動作は次のとおりでした。コードまたはセットアップの問題に関連していると考えられます。しかし、さらなるテストにより、これは当てはまらないことが判明しました。
jQuery の click() 関数は、ターゲット要素でクリック イベントをトリガーする目的を果たします。要素にイベント ハンドラーが定義されていない場合、click() は単純にデフォルトのブラウザ ハンドラーをトリガーし、リンク ナビゲーションを開始します。
代替ソリューション
If click()この動作は適切ではありません。利用可能な代替オプションがあります:
jQuery の Trigger() メソッドを使用する:
$('a').trigger('click');
バニラ JavaScript を使用する:
document.getElementById("a_link").click()
window.location を直接変更する:
window.location = "new_page.html";
以上がClick() はリンク ナビゲーションのシミュレートに使用できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。