集中することを学ぶ()

Jennifer Aniston
Jennifer Anistonオリジナル
2025-02-21 10:39:14667ブラウズ

Learning to focus()

集中することを学ぶ()

キーテイクアウト

  • Webアクセシビリティの場合、JavaScript主導のインタラクティブウィジェットでは、フォーカスの管理が重要です。プログラマティックフォーカスを使用して、マウスを使用しなくても、ユーザーがインターフェイスのさまざまな領域と対話できるようにすることが重要です。 スクロールトップを変更するアニメーションでは、画面リーダーの出力とキーボードのインタラクションがページの正しい領域から継続するように、要素のデフォルト関数をオーバーライドする必要があります。これは、Tabindex属性を使用して宛先フラグメントをプログラム的にフォーカブルにし、アニメーションのコールバックにjavascriptフォーカス()メソッドを含めることで実現できます。
  • ダイアログまたはモーダルウィンドウを閉じるとき、ダイアログを開いた要素を再び焦点を合わせることが論理的です。これは、メモリにDOMノードを保存するか、後で使用するためにマーカーを書き込むことで実行できます。これにより、ユーザーはページ上の自分の位置を知ることができ、再び自分の場所を見つけるためにドキュメントを通り抜けなければならないのを防ぎます。
  • 幸運のおかげで、私は機能的な目を持っています。 Webページを横断することになると、これはページのある部分から別の部分に私の焦点をシフトするには、半意識的に私の球体外筋に契約し、眼球を一部回転させること以外に何も必要としないので、これは恩恵のようなものです。
  • 私の視覚的 - したがって、認知的な焦点が変化したと言われるかもしれませんが、ユーザーインターフェイス自体は私の注意が変わったことを知りません。少なくとも、私が新しく精査された地域と物理的に交流し始めるまで。別の言い方をすれば、眼球を回転させることは記録されていないイベントです。
ここには非常に一般的ですが、頻繁には延長されていないアクセシビリティの問題があります。目(そしてマウスの手を指す)を使用していない場合、それと対話するために何かに「集中」するにはどうすればよいですか?あなたが知っていると確信しているように、答えはプログラムの焦点を介してです。ただし、「フォーカス可能な」要素をデザインに組み込むだけではありません。場合によっては、ユーザーではなく、異なる領域間でフォーカスを移動する必要があるのはユーザーに代わってインターフェイスです。これには、開発者側の意図的なフォーカス管理が必要です。 アクセシビリティの場合、最も単純なJavaScript駆動型のインタラクティブウィジェットでさえ、フォーカスの管理が不可欠ですが、自動化されたQA

ツールでテストすることはほとんど不可能です。だから私は今日いくつかの簡単な例をあなたに連れて行きたいです。

Scrolltopアニメーション

この例では、リンクのターゲットフラグメントに突然ジャンプする代わりに(#section1、レッド)、この目的地に穏やかに案内されるように、同じページのナビゲーションリンクを「強化」したことを想像するように勧めます。 JavaScript Scrolltopアニメーションを介して。この手法を使用する際のアクセシビリティに関する重要なことは、要素のデフォルト関数をオーバーライドする必要性です。

これを行うことにより、ブラウザに、標準、予想、または相互運用可能なことを避けるようにブラウザに伝えています。リンクを

event<span>.preventDefault();</span>
リンクに触れていると言っています。実際、リンクが実際にユーザーをページフラグメントに正しく使用することを確認する唯一の方法は、JavaScriptをオフにすることです。さて、

ページフラグメントにリンクするだけで、JavaScriptをオフにするように - ブラウザは本質的にこのフラグメントに焦点を合わせます。これは、スクリーンリーダーの出力とキーボードインタラクションが現在基づいている場所です。 Scrolltopをアニメーション化することにより、そのようなフォーカスアクションは行われません。つまり、画面リーダーの出力とキーボードのインタラクションは、もはや視界にないページの領域から続きます。これは良くありません。

治療法 JavaScriptを介して宛先フラグメントに焦点を合わせる必要があります。まず、Fragmentをプログラム的に焦点を当てる必要があります。これには、Tabindex属性の使用が必要です。 -1のTabindex値は、スクリプトが要素に焦点を合わせることができるが、ユーザーではないことを意味する特別な値です。これはTabindexよりも望ましいです:0この場合、この非対話要素がTABキーを使用して焦点を合わせる必要がある理由がないためです。

注:パトリックなどのコメントに感謝します。これは、これが修正されたTabindex値に「0」ではなく「-1」を使用する必要があるという事実を指摘してくれました。 🎜>

2番目のタスクは、アニメーションのコールバックにjavascriptフォーカス()メソッドを含めることであり、アニメーションが終了した後、フラグメントが

最後に、フラグメントにリンクするだけで起こるように、URLにサブページの場所を記録することをお勧めします(例:http:// my-site/#section1)。これにより、特定のセクションへのリンクとしてアドレスをコピーできます(つまり、「深いリンク」ができます)。 Focus()が行われた後の次の行を含めます: もちろん、「セクション1」は、対応するリンクのHREFが何であれ、#。

を除いて変数に置き換えます。
<span><span><span><section</span> id<span>="section1"</span> tabindex<span>="-1"</span>></span>
</span>    ...
<span><span><span></section</span>></span></span>

結果 小さなCodepenデモを以下に埋め込みます。習慣的なキーボードユーザーがそうするように、タブとシフトタブでそれを使用してみてください。

CodepenのSitePoint(@SitePoint)のペンIDXJLを参照してください

JavaScriptでTabindex属性をその場で追加していることに注意してください。スクロールしているセクション(フラグメント)に焦点を合わせているので、知覚された場所は単なる視覚以上のものです。つまり、新しいセクションに移動した後にTABキーを押した場合、そのセクション内の次の焦点の要素に焦点を合わせます。次の例では、「heydonworks.com」というハイパーリンクの読み取り

event<span>.preventDefault();</span>
セクション1に焦点を合わせていなかった場合、タブキーを押すと、扇動リンクに続いて次の要素に焦点を合わせて、ビューポートをナビゲーションブロックに戻します。言い換えれば、キーボードユーザーは正方形に戻ります。

閉じるダイアログ(モーダルウィンドウ)
<span><span><span><section</span> id<span>="section1"</span> tabindex<span>="-1"</span>></span>
</span>    ...
<span><span><span></section</span>></span></span>

これが別の小さな例です。ユーザーが

問題は、「ダイアログが閉じたときに何が焦点を合わせるのか」ということです。何もしないと、新しく隠されたダイアログは必ずしも焦点を失いますが、その代わりに何も得られません。多くのユーザーエージェントでは、これはがデフォルトに焦点を合わせていることを意味し、ユーザーがドキュメントを歩き回って再び自分の場所を見つけることを意味します。

ダイアログを開いた要素を再び焦点を合わせる方が論理的です。これは、メモリにDOMノードを保存するだけで、このように後で使用するためにマーカーを書くことで簡単に行うことができます。 ダイアログのclose()メソッドの最後に、元の要素に焦点を合わせるだけです。

ほとんどのスクリーンリーダーは、ボタンがリモーシングされているため、ページのタイトル、フォーカスボタンを発表します。そうすれば、あなたはあなたがどこにいるかを知っています。この方法を使用したダイアログの例は、必要に応じてテストに利用できます。
<span>document.getElementById('section1').focus();</span>
結論

進行性の強化とアクセシビリティを混同することはよくある間違いです。 JavaScriptの操作に何かを劣化させることを確認することは、(この場合のように)オフになっていることを意味します。確かに、JavaScriptのない人がアクセスしやすくなりますが、ほとんどのキーボードとスクリーンリーダーのユーザーは、他の人と同じようにJavaScriptの助けを借りてアプリケーションと対話します。秘trickは、すべてのユーザーの異なる動作と入力、および使用する支援技術を尊重する方法でJavaScriptを使用することです。もう1つ:Ember.jsまたはAngularjsで構築された1ページのアプリケーションでの作業を担当した場合、JavaScriptフォーカス()メソッドのコードベースをグレップします。このようなアプリケーションは、「ビュー」を使用してナビゲーションを完全に書き直します。単数ページの動的な再構築。慎重なフォーカス管理がなければ、そのような方法でDOMを再構築することは、アクセシビリティをかなり迅速に台無しにする義務があります。グレップが数杯未満のインスタンスを見つけた場合、やるべきことがたくさんあるかもしれません。

焦点と集中の改善に関するよくある質問

私の焦点と集中力を改善するためのいくつかの実用的な方法は何ですか?

焦点と集中を改善するためのいくつかの実用的な方法があります。第一に、健康的なライフスタイルを維持することが重要です。これには、十分な睡眠、バランスの取れた食事を食べること、定期的な身体活動が含まれます。第二に、マインドフルネスと瞑想は、あなたの脳をよりよく集中するように訓練するのに役立ちます。第三に、デバイスの通知をオフにするなどの注意散漫を最小限に抑えることで、手元のタスクに集中するのに役立ちます。最後に、定期的な休憩を取ることは、長期的には実際にあなたの焦点と生産性を向上させることができます。学ぶ。これは、気を散らすものを最小限に抑えた静かで明るいスペースを意味します。また、学習セッションを管理しやすいチャンク、通常は25〜30分の長さで、短い休憩を取得することも役立ちます。この技術は、ポモドロ技術として知られています。さらに、各学習セッションで明確で達成可能な目標を設定すると、やる気と集中力を維持できます。

特定の食品は私の集中を改善できますか?魚や亜麻仁などのオメガ3脂肪酸が豊富な食品は、脳の健康をサポートすることが知られています。さらに、果物や野菜、特に抗酸化物質が豊富なものは、脳を損傷から保護し、認知機能を改善するのに役立ちます。赤身の肉やマメ科植物のようなタンパク質が多い食品は、脳の注意を喚起し、集中させるのにも役立ちます。脳にとって多くの利点。それは血流を増加させ、脳の健康と認知機能を改善します。エクササイズはまた、エンドルフィンを放出し、気分を改善し、ストレスを軽減し、焦点と集中力を改善します。あなたのタスクと彼らの重要性と緊急性に基づいてそれらを優先します。燃え尽きを避けるために定期的な休憩をとることも役立ちます。さらに、デバイスの不必要な通知をオフにするなどの注意散漫を最小限に抑えることで、タスクに集中するのに役立ちます。

瞑想は焦点と集中力を改善するのに役立つことができますか?それはあなたの脳を訓練し、現在の瞬間に集中し、気晴らしを無視します。定期的な練習は、注意力の向上と認知機能の改善につながる可能性があります。

睡眠は焦点と集中力にどのように影響しますか?睡眠不足は、注意、焦点、意思決定スキルを損なう可能性があります。したがって、十分な質の高い睡眠を取得することは、焦点と集中力を維持するために不可欠です。

一般的な注意散漫は何ですか?それらを回避するにはどうすればよいですか?デバイスで。これらを避けるために、メールやソーシャルメディアをチェックするために特定の時間を設定できます。不要な通知をオフにすると、気晴らしを最小限に抑えることができます。

脳をより良く訓練するにはどうすればよいですか?

脳のトレーニングをより良くすることで、定期的な練習を通して達成できます。マインドフルネスや瞑想などのテクニックが役立ちます。さらに、パズルとゲームで脳に挑戦することは、認知機能と焦点を改善することもできます。と集中。したがって、深い呼吸、ヨガ、マインドフルネスなどのテクニックを通じてストレスを管理することは、焦点と集中力を改善するのに役立ちます。

以上が集中することを学ぶ()の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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