検索
ホームページウェブフロントエンドhtmlチュートリアルCSS Secret Garden: カスタム Underline_html/css_WEB-ITnose

『CSS Secrets』は、@Lea Verou による最新の本で、CSS に関する小さな秘密を説明しています。これは CSSers にとって読む価値のある本です。一定期間読んだ後、私、@範囲、@彦子は、関連する読書感想文を W3cplus で公開し、皆さんと共有します。

デザイナーは非常にこだわりのある人々のグループです。私たちは常に、何かをカスタマイズしてから、必要な視覚効果に非常に似たものになるように慎重にデザインすることを好みます。これにより、デザインがより直観的で使いやすくなります。結局のところ、デフォルトで良いと思われるものはほとんどありません。

テキストの下線は、私たちが本当にカスタマイズしたいものの 1 つです。デフォルトのものはうまく機能しますが、邪魔に感じられ、ブラウザごとにレンダリングが異なります。テキストの下線は Web の初期から使用されてきましたが、それをカスタマイズするこれ以上の方法はまだ見つかっていません。 CSS の登場後も、オン/オフの権限しかありません:

text-decoration: underline;

以前と同様、適切なツールがない場合は、自分で解決する必要があります。テキストの下線をカスタマイズする方法がないため、境界線を使用してそれを偽装する必要があります。そこで思い浮かぶ最初の CSS トリック:

a[href] {    border-bottom: 1px solid gray;    text-decoration: none;}

border-bottom を使用してテキストの下線をシミュレートすると、色、太さ、スタイルを制御できますが、完璧ではありません。下の図で見ることができます

これらの「下線」とテキストの内容の間には非常に大きなギャップがあり、まるでテキストの次の行にあるようです。次のように、display: inline-block; と小さな line-height 値を指定することで、この問題を解決することができます:

display: inline-block;border-bottom: 1px solid gray;line-height: .9;

これにより、下線がテキストに近づきますが、通常のテキストの折り返しに影響します。写真は示す。

境界線に基づいて「下線」の問題を解決しようとしますが、テキストを折り返す必要があります - これはめちゃくちゃです

さて、下線をシミュレートするために内側のシャドウ box-shadow を使用してみましょう:

box-shadow: 0 -1px gray inset;

ただし、これはボーダーとは異なります。ボトムにも同じ問題がありますが、影がテキストにわずかに近い点が異なります。明確で柔軟、カスタマイズ可能な下線を取得する方法はありますか?

ソリューション

最良のソリューションは、多くの場合、最も予期せぬ場所から生まれます。この例では、background-image の役割とその関連プロパティが関係します。おかしな話に聞こえるかもしれませんが、ちょっと待ってください。背景はテキストを完全に包み込むことができ、background-size など、CSS3 の背景と境界線のいくつかの新しい背景関連プロパティに基づいて、背景を非常に正確に制御できます。 CSS グラデーションを介して背景画像を生成できるため、個別の HTTP リクエストを追加する必要さえありません。

background: linear-gradient(gray, gray) no-repeat;background-size: 100% 1px;background-position: 0 1.15em;

以下の画像で、非常に素晴らしい効果を確認できます。

しかし、小さな改善をすることもできます。 p や y などの文字にアンダースコアがどのように入っているかに注目してください。周囲に適切な余白があったほうがよいでしょうか。背景が単色の場合、2 つのテキストシャドウを設定できます。そのうちの 1 つは背景と同じ色です:

background: linear-gradient(gray, gray) no-repeat;background-size: 100% 1px;background-position: 0 1.15em;text-shadow: .05em 0 white, -.05em 0 white;

効果は次のようになります:

ここでは非常に柔軟であるため、グラデーションが使用されています。 。たとえば、点線の下線を作成するには、次のように記述します:

background: linear-gradient(90deg,gray 66%, transparent 0) repeat-x;background-size: .2em 2px;background-position: 0 1em;

効果は以下のようになります:

このようにして、カラー スケールを通じて点線の間隔を制御し、背景を通じて点線のサイズを制御できます。サイズ。

練習として、スペルミスを強調するために使用されるような赤い波線の下線を作成してみることができます (ヒント: 2 つのグラデーションが必要です)。以下の例で解決策が見つかりますが、答えを見る前に、次のことを試してください。まずは自分でやってみよう - もっと楽しくなるよ。

ヒント: 将来のテキストの下線

将来、下線をカスタマイズするのにそれほど面倒な作業は必要なくなります。 CSS3 テキスト装飾では、次のように、このためにカスタマイズされたプロパティがいくつかあります:

  • text-decoration-color は、下線やその他の装飾の色をカスタマイズするために使用されます
  • text-decoration-style は、装飾スタイルをカスタマイズするために使用されます(例: 実線、破線、波線など)
  • text-decoration-skip スペースのスキップ、文字のまたがり、その他のオブジェクト
  • text-underline-position 下線の位置の微調整

ただし、これらのプロパティは Currentブラウザのサポートは非​​常に最小限です。

詳しく読む

  • CSS デザイン: カスタム下線
  • CSS でカスタムテキストの取り消し線を作成する
  • より完璧なリンク下線を目指して
  • カスタマイズされた下線
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTML、CSS、およびJavaScriptの理解:初心者向けガイドHTML、CSS、およびJavaScriptの理解:初心者向けガイドApr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割:Webコンテンツの構造HTMLの役割:Webコンテンツの構造Apr 11, 2025 am 12:12 AM

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTMLとコード:用語を詳しく見るHTMLとコード:用語を詳しく見るApr 10, 2025 am 09:28 AM

htmlisaspecifictypeofcodefocuseduructuringwebcontent

HTML、CSS、およびJavaScript:Web開発者に不可欠なツールHTML、CSS、およびJavaScript:Web開発者に不可欠なツールApr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML、CSS、およびJavaScriptの役割:コアの責任HTML、CSS、およびJavaScriptの役割:コアの責任Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは初心者のために簡単に学ぶことができますか?HTMLは初心者のために簡単に学ぶことができますか?Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTMLでの開始タグの例は何ですか?HTMLでの開始タグの例は何ですか?Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?Apr 05, 2025 pm 01:24 PM

メニューで点線のラインセグメンテーション効果を設計する方法は?メニューを設計するときは、通常、皿の名前と価格の間に左右に合わせることは難しくありませんが、真ん中の点線またはポイントはどうですか...

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境