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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

Q&A

解決済

1回答

3587閲覧

擬似要素(:after)のPositon を%で指定しても間隔がズレてしまう。

juke-footwork

総合スコア23

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

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

0グッド

1クリップ

投稿2022/01/11 14:27

擬似要素の位置を一定の間隔にしたく、%で指定しているのですが、ブラウザの幅を変えると、位置がズレていってしまい困っています。具体的には、以下の画像のような形です。

デフォルト時:
イメージ説明

ブラウザの幅を変えた時:
イメージ説明

画像のように、「あのね明日は何曜日」という文言の前後に、斜めの線を配置しているのですが、前の方のbeforeで指定した方は
ブラウザを動かしても一定の間隔がkeepできているのですが、afterで指定した後ろの「/」の方だけ、なぜか間隔が広がってしまいます。

ちなみにコードはこちらです。

HTML

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 6 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 7 <title>position</title> 8 <link rel="stylesheet" href="styles.css"> 9</head> 10<body> 11 12 <section> 13 <div class="container"> 14 <h2 class="heading">あのね明日は何曜日</h2> 15 </div> 16 </section> 17 18</body> 19</html>

CSS

1 2.container { 3 max-width: 1002px; 4 width: calc( 1002 / 1280 * 100% ); 5 margin: 0 auto; 6} 7 8.heading { 9 font-size: calc(100/1280*80vw); 10 padding-left: calc( 84 / 1002 * 100% ); 11 padding-bottom: calc( 106 / 1002 * 100%); 12 position: relative; 13} 14 15.heading:before, .heading:after { 16 content: ''; 17 position: absolute; 18 border-radius: 11px; 19} 20 21.heading:before { 22 top: 5%; 23 height: 51%; 24 border-left: solid min( calc( 100 / 1280 * 14vw ), 14px); 25 left: calc( 23 / 1002 * 100% ); 26 transform: rotate(-32.2deg); 27} 28 29.heading:after { 30 top: 10.4%; 31 height: 51%; 32 border-right: solid min( calc( 100 / 1280 * 14vw ), 14px); 33 right: calc( 21 / 1002 * 100% ); 34 transform: rotate(30deg); 35}

どなたか原因・解決方法を教えていただけないでしょうか??
大変恐れ入りますが、どうかよろしくお願いいたしますm m

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

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

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

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

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

guest

回答1

0

ベストアンサー

.heading幅が
.headingの中に入っている文字の幅ではなく
.containerまで広がってるはずですので
right:0の位置が想定と違うのではないでしょうか。

以下の記述を追加してみるとどうでしょうか?

css

1.heading { 2 display:inline-block; 3 padding-right: calc( 84 / 1002 * 100% );

投稿2022/01/11 15:12

recal

総合スコア1126

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

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

juke-footwork

2022/01/11 17:14

いつもありがとうございますm m 教えていただいた記述を追加したら上手くいきました! display:inline-block; を追加するという考えは全くなかったので、本当に助かりましたm m 本当にありがとうございましたm m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問