目次
CSSを使って正円を描きます
border-radius の仕組み
ホームページ ウェブフロントエンド htmlチュートリアル 境界線の半径 50% と 100%_html/css_WEB-ITnose

境界線の半径 50% と 100%_html/css_WEB-ITnose

Jun 24, 2016 am 11:25 AM

最近、私は自分が書いたコードを見直していました。以前にコードを書いたとき、なぜそのように書いたかを真剣に考えたことはなく、ただ経験や既存のコードに基づいて書いていました。あるいは、そう書いている理由はなんとなく分かっているのかもしれないが、仕様書をじっくり読んだことがないので、具体的な内容は分からない。そこで、「なぜ」「なぜこれを書くのか」をできるだけ自分に問いかけることにしました。今、これを頻繁に自分に問いかけることで、たくさんの「発見」の瞬間が得られたことに気づきました。その中の 1 つを皆さんと共有したいと思います。

CSSを使って正円を描きます

Web上では、背景色や円形の画像など、円が使われている箇所をよく見かけます。

通常、円を実現するには CSS の border-radius 属性を使用します。まず正方形を描画し、次にその border-radius を 50% に設定します。しかし、なぜ50%なのでしょうか?私はこの問題について考えたことはなく、角の半径を正方形の高さまたは幅の半分に設定すると円が得られると考えていました。

これは 150 ピクセル x 150 ピクセルの正方形で、四隅の半径を 50% に設定します。 W3C border-radius の仕様定義によれば、border-radius の値がパーセンテージの場合、それはボーダー ボックスの幅と高さに対する相対パーセンテージです。この例では、ボックスの幅と高さは両方とも 150 ピクセルなので、50% は 75 ピクセルに相当します。

border-radius の仕組み

しかし時々、border-radius: 100%; を使用して、少し前のプロジェクトで、何も考えずに使用しているのを見かけます。 50%と変わらないように見えます。理由は何ですか?

Lea Verou 氏の講演「The Humble Border Radius」の中で、彼女は、W3C には一致する曲線について次の仕様があると述べました。隣接する 2 つの角の半径の合計が、対応するボックスの辺の長さを超える場合、ブラウザは再計算する必要があります。それらは一致しないでしょう。

左上隅のコーナー半径が 100% に設定されている場合、フィレットは正方形の左下隅から右上隅まで広がります。これは、コーナー半径を 150px に設定するのと同じです (つまり、正方形のサイズ)。右上隅のフィレット半径も 100% に設定すると、隣接する 2 つのフィレットの合計は 200% になります。この状況は当然許可されないため、ブラウザは再計算して、右側の丸い角のスペースを均等にし、正方形に正確に収まるまで 2 つの丸い角の半径を拡大縮小して、半径が 50 % になるようにします。

同様に、ブラウザは他の角丸にも同じ計算を適用し、計算の結果、各角丸の半径が 50% になるので、プロトタイプが表示されます。 border-radius が 150px に設定されている場合でも、ブラウザーは 75px で丸い角を描画します。これは、ブラウザーがこの正方形に対して許可する最大の丸い角半径です。

結論

すべての丸い角の半径が 100% に設定されている場合、ブラウザはグラフィックスの実際の状況に基づいていくつかの計算を実行し、丸い角がグラフィックスにぴったりフィットすることを確認します。ただし、すべてのグラフィックスの

border-radius を 100% に設定することがパフォーマンスに影響するかどうかはわかりません。

さて、先週書いた乱雑な CSS を整理してみます...

元のリンク: Border-radius 50% vs 100%

Weibo をフォロー: フロントエンド外部ジャーナル コメント

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

< Progress>の目的は何ですか 要素? < Progress>の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

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

< datalist>の目的は何ですか 要素? < datalist>の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

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

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

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

< meter>の目的は何ですか 要素? < meter>の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

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

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

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

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

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

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

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

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

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

See all articles