テキストをアクセスしやすい状態に保ちながら、文字の半分だけをスタイル設定するという課題。しばらくの間、開発者の興味をそそられてきました。この記事では、純粋な CSS と JavaScript を組み合わせて動的実装を行うソリューションを解明します。
単一文字のスタイルを設定するには、単に以下を追加します。 「.halfStyle」クラスを対応するspan要素に追加します。秘訣は、「data-content」属性を使用して擬似要素の「:before」コンテンツを動的に設定することにあります。これにより、各スパンに必要な文字を指定できます。
ダイナミック テキストに部分的なスタイルを適用する場合、jQuery はプロセスを自動化します。文字を反復処理することで、アクセシビリティのための非表示要素と、「.halfStyle」クラスを使用した表示要素が作成されます。
<code class="css">.halfStyle { position: relative; display: inline-block; font-size: 80px; /* or any font size */ color: black; /* or transparent, any color */ overflow: hidden; white-space: pre; } .halfStyle:before { display: block; z-index: 1; position: absolute; top: 0; left: 0; width: 50%; content: attr(data-content); overflow: hidden; color: #f00; }</code>
< h3>JavaScript の実装
<code class="javascript">$('.textToHalfStyle').each(function() { var $el = $(this); var text = $el.text(); var chars = text.split(''); for (var i = 0; i < chars.length; i++) { $el.append('<span aria-hidden="true" class="halfStyle" data-content="' + chars[i] + '">' + chars[i] + '</span>'); } });</code>
このソリューションは、スクリーン リーダーに隠しテキストを提供することでアクセシビリティを確保します。非表示要素は元のテキストを保持し、表示要素はスタイル付き部分を表示できるようにします。
結論
この手法を使用すると、目的の効果を達成できます。静的か動的かを問わず、テキスト内の文字を部分的にスタイル設定します。 CSS と JavaScript の組み合わせを利用して、デザインの視覚的な魅力を高めながらアクセシビリティを維持します。以上がCSS と JavaScript で半分の文字をスタイルする方法: アクセシビリティの追求?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。