無効化された入力要素のイベント処理
無効化された入力要素は、性質上、マウス イベントに応答しません。ほとんどのブラウザでは無効な要素から DOM ツリーまでのイベントの伝播が許可されていますが、この動作は Firefox と矛盾しています。すべてのブラウザーで機能する効果的なソリューションを見つけるのは難しい場合があります。
クロスブラウザー ソリューション
クロスブラウザーの互換性を実現するには、無効な入力。このオーバーレイ要素のクリック イベントをキャッチすることで、意図した動作を効果的にシミュレートできます。その仕組みは次のとおりです。
<div>
$("div > div").click(function (evt) { $(this).hide().prev("input[disabled]").prop("disabled", false).focus(); });
このソリューションは、無効な入力をカバーするオーバーレイ div を作成します。ユーザーがオーバーレイをクリックすると、クリック イベント ハンドラーがトリガーされ、入力が無効になり、ユーザーの操作が可能になります。
結論
入力要素はネイティブで無効になっていますが、標準のイベント処理がない場合は、オーバーレイ要素を配置し、その要素上でクリック イベントをキャッチすることで、完全なブラウザ間の互換性を実装できます。このアプローチにより、無効化された入力要素が期待どおりに動作し、パフォーマンスを損なうことなく機能を維持できるようになります。
以上がブラウザ間で無効になった入力要素のクリック イベントを処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。