ホームページ ウェブフロントエンド htmlチュートリアル cssで小さな三角形を実装する(原理)_html/css_WEB-ITnose

cssで小さな三角形を実装する(原理)_html/css_WEB-ITnose

Jun 24, 2016 am 11:23 AM

レンダリングを 図 1 に示します: (簡単なデモですが、少し見苦しいですが、気にしないでください)

PS: IE、FF、chrome、360 セキュア ブラウザと互換性があります

まずそれについて話しましょう 原則は 図 2 に示すとおりです:

この div のスタイルは次のとおりです:

div{ width: 0px; height: 0px; border-width: 20px; border-style: solid; border-color: lightgreen pink yellow lightblue;}
ログイン後にコピー

説明: div の幅と高さが 0 の場合、境界線の幅を に等しくします。 色を設定すると、div が 4 つの小さな三角形に分割されているように見えることがわかります。他の 3 つ (方法: これら 3 つの側面の色を透明に設定します)。

上の三角: (

図 3

)

対応する CSS コード:

#triangle{ width: 0px; height: 0px; border-width: 20px; border-style: solid; border-color: transparent transparent yellow transparent;}
ログイン後にコピー

さまざまなブラウザにできるだけ適応できるようにするために、さらに数行追加しましょう。コード (主に IE の互換性の問題を解決するため):

 1 #triangle{ 2  width: 0px; 3  height: 0px;<strong> 4  *width: 40px; 5  *height: 40px; 6  font-size: 0; 7  line-height: 0; 8  overflow: hidden;</strong> 9  border-width: 20px;<strong>10  border-style: dashed dashed solid dashed;11  border-color: transparent transparent yellow transparent;</strong>12 }
ログイン後にコピー

説明:

①border-color: 透明 透明 黄色 透明

図 2 によると、必要なものは上の三角形であるため、保持は下の境界線なので、他の 3 つの辺を透明に設定します。

②border-style: 破線 破線 実線 破線

IE6 は透明属性をサポートしていないため、スタイルを設定します。他の 3 つの辺を

破線に設定すると、境界線の幅が非常に大きい場合、破線が非表示になります。 (私のPCにはie6がないので、実践していません。すいません)

③font-size: 0; line-height: 0; overflow: hidden; この3つの文が追加されていない場合、次のような効果が発生します:

つまり、IE では、表示されるのは三角形ではなく、台形です。

④ 最後に、さらに 2 つの CSS ハックを追加しました:

*width: 40px; *height: 40px; 関連する質問が見つからなかったので、何気なく width&height スタイルに

を追加すると、小さな三角形が表示されました。

IE では、div の幅と高さには境界線も含まれる、という感じです (これはまだよくわかりません

答えてくれる専門家がいるといいのですが)。

IE でこの問題を解決するために、最終的にこれら 2 つの CSS ハックを追加しました。安全ではないと思われる場合は、「_width: 40px; _height: 40px;」を追加することもできます

追記: ① IE6 と IE7 は「*」を認識でき、IE6 は「_」を特定して検索できます。 CSSハック」。

② *幅は境界線の幅の2倍に設定する必要があります。 *高さは同じです。

下の三角形、左の三角形、右の三角形については、上の 2 つの CSS 文を変更するだけで済みます。その他の変更は次のとおりです。

下の三角:

border-style: solid dashed dashed dashed;border-color: lightgreen transparent transparent transparent;
ログイン後にコピー

左三角:

border-style: dashed solid dashed dashed;border-color: transparent pink transparent transparent;
ログイン後にコピー

直角三角形:

border-style: dashed dashed dashed solid;border-color: transparent transparent transparent lightblue;
ログイン後にコピー

最后,给出效果图1的代码:

 1 /* css */ 2 *{ 3  margin: 0px; 4  padding: 0px; 5  text-align: center; 6 } 7 #container{ 8  position: relative; //这句很重要,因为小三角是相对父元素#container来绝对定位的 9  width: 50px;10  height: 40px;11  border:1px solid lightblue;12  margin: 200px auto;13  padding: 20px;14  15 }16 #chat{17  width: 50px;18  height: 40px;19  background-color: lightblue;20 }21 #triangle{22  position: absolute; //设置小三角绝对定位23  width: 0px;24  height: 0px;25  *width: 14px;26  *height: 14px;27  font-size: 0;28  line-height: 0;29  overflow: hidden;30  border-width: 7px;31  border-style: dashed dashed dashed solid;32  border-color: transparent transparent transparent lightblue;33  top: 33px; //33px:父元素#container的内边距20px + #chat宽度的一半20px - 自身元素#triangle的边宽7px =33px34  left: 70px; //70px: #chat的宽度50px + 父元素#container的内边距20px =70px35 }
ログイン後にコピー

/* html代码 */<div id="container"> <div id="chat"></div> <div id="triangle"></div></div>
ログイン後にコピー

 

如有不足之处,欢迎批评建议,  O(∩_∩)O谢谢

 

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

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

&lt; Progress&gt;の目的は何ですか 要素? &lt; Progress&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

&lt; datalist&gt;の目的は何ですか 要素? &lt; datalist&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? Mar 17, 2025 pm 12:20 PM

記事では、HTML5クロスブラウザーの互換性を確保するためのベストプラクティスについて説明し、機能検出、プログレッシブエンハンスメント、およびテスト方法に焦点を当てています。

&lt; meter&gt;の目的は何ですか 要素? &lt; meter&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? Mar 17, 2025 pm 12:27 PM

この記事では、ブラウザのユーザー入力を直接検証するために、必要、パターン、MIN、MAX、および長さの制限などのHTML5フォーム検証属性を使用して説明します。

ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? Mar 20, 2025 pm 05:56 PM

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

&lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? &lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? Mar 20, 2025 pm 06:05 PM

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。

Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Apr 04, 2025 pm 11:54 PM

GiteEpages静的Webサイトの展開が失敗しました:404エラーのトラブルシューティングと解像度Giteeを使用する

See all articles