質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

1390閲覧

円に部分的にborderプロパティを付けられる仕組みについて教えて頂きたいです。

Woodie

総合スコア5

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/04/18 08:31

前提・実現したいこと

CSSのプロパティに関する質問です。
円にborderプロパティで部分的にボーダーをつけたい時、border-leftborder-rightとすると、円の90度分のみを指定することができると思うのですが、これはどういった仕組みなのでしょうか。

例えば、ローディングアイコンを作りたくて、以下のように90度分だけ欠けた円を作りたい場合、

border-radius: 50%; border: 2px solid #333; border-right: 5px solid transparent;

のようにすると、右側1/4が欠けた円ができると思います。

ここで、何故border-rightプロパティでこのように円の右側だけを部分的に指定できるのでしょうか。

元要素の四つ角をborder-radius:50%;で丸めたときに、円の頂点からから45度から135度は、丸める前の要素でいう右辺なので、border-rightで指定できるからだ、と仮説を持ったのですが、どなたかご教授いただけますでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

実際は”「円」じゃないから”です。
border-radiusはあくまで要素の角を丸める指定なのです。
下記だけにしてみると分かると思います。

css

1 border: 2px solid #333; 2 border-right: 5px solid transparent;

要は「全部色を付けた後に1か所だけ色を透明にする」というやり方になります。
この方法の方がtop,bottom,left,rightにそれぞれ指定するよりも短く簡潔に書けます。

書き漏れたので追記:
つまり質問者さんの仮説は「合っている」ということになります。

投稿2020/04/18 08:37

編集2020/04/18 08:40
m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Woodie

2020/04/18 12:00

回答ありがとうございます!仮説があっていたようでよかったです! 直感的に円の右側だからborder-rightが付けられるのではなく、単にborder-radiusは要素の角を丸めているだけなのであって、丸めた後であっても、要素の右辺であることには変わりはないということですね。 borderで一括で指定した後にrightを指定するとこのようにすっきりと書けるのですね! ありがとうございます!
m.ts10806

2020/04/18 20:56

hrを完全1pxにしたいときにも使えます。borderをnoneにしたあとにtopだけ1pxにする。
guest

0

ベストアンサー

デベロッパーツールで、border-radiusの値を0⇒50%まで変えてみましょう。下記例で言うとwidthも値を0まで変えてみましょう。どのような仕組みかがわかると思います。

CSS

1div { 2 border-radius: 15%; 3 border: 20px solid #333; 4 border-color: red green blue yellow; 5 width: 10vw; 6 height: 10vw; 7} 8```**動くサンプル:**[https://jsfiddle.net/pb9ouxqr/](https://jsfiddle.net/pb9ouxqr/) 9 10--- 11 12【初心者向け!Chromeの検証機能(デベロッパーツール)の使い方】 13[https://saruwakakun.com/html-css/basic/chrome-dev-tool](https://saruwakakun.com/html-css/basic/chrome-dev-tool) 14 15【ChromeデベロッパーツールでCSSをチェックする方法 | なんでものびるWEB】 16[https://nandemo-nobiru.com/2944/](https://nandemo-nobiru.com/2944/)

投稿2020/04/18 08:41

kei344

総合スコア69606

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Woodie

2020/04/18 11:52

回答ありがとうございます! なるほど、単に`border-radius`は要素の角を丸める為のもので、要素自体に付けられる`border`プロパティは依然として継承される。故にこう言った形になるのですね。 0%と50%以外を試していなかったので、気付きませんでした、ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問