ホームページ > ウェブフロントエンド > CSSチュートリアル > IE で Focus() が機能しないのはなぜですか?どうすれば修正できますか?

IE で Focus() が機能しないのはなぜですか?どうすれば修正できますか?

Linda Hamilton
リリース: 2024-11-02 06:41:02
オリジナル
749 人が閲覧しました

Why Doesn't Focus() Work in IE and How Can I Fix It?

IE でフォーカスが機能しない: 解決策

IE7 で focus() 関数が機能しない状況では、入力フィールド内にカーソルを配置するには、別のアプローチが必要です。

IE でこの問題に対処するには、遅延実行動作のため setTimeout 関数を利用します。次のコードを実装します。

<code class="javascript">setTimeout(function() { document.getElementById('myInput').focus(); }, 10);</code>
ログイン後にコピー

このコードは、IE の応答遅延に対応して、focus() 関数を実行する前に 10 ミリ秒の遅延を開始します。

ただし、Opera では問題が解決しない可能性があります。 Opera でフォーカスを設定するための潜在的なソリューションを検討することを検討してください。

要素がすぐに利用できない状況に対応する高度なソリューションには、要素がアクセス可能になるまで短い遅延を設けて再試行することが含まれます。これにより、読み込みの遅いページや読み込みに時間がかかる要素との互換性が確保されます。次のコードを実装します。

<code class="javascript">setTimeout(

function( ) {

    var el = document.getElementById( &quot;myInput&quot; ) ;
    ( el != null ) ? el.focus( ) : setTimeout( arguments.callee , 10 ) ;

}

, 10 ) ;</code>
ログイン後にコピー

このコードは、要素が利用可能かどうかをチェックする再帰的な setTimeout 関数を設定し、成功するまで 10 ミリ秒ごとにその要素にフォーカスしようとします。

以上がIE で Focus() が機能しないのはなぜですか?どうすれば修正できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート