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

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

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

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

Q&A

解決済

2回答

175閲覧

文字列にbeforeを当てて別の文字列を指定したのですが

tokyodesk

総合スコア56

CSS3

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

0グッド

0クリップ

投稿2017/09/17 22:01

編集2017/09/18 02:47

縦に並んでいるのですが、縦方向に空白が空いていました。
これはbeforeの仕様なのでしょうか。
また、この空白を狭めたいときに、before要素に対してマイナスマージンとしてmargin-bottomを指定するのは適切な書き方でしょうか。

<html> <head> <meta charset="utf-8"> <title>ABC</title> <link rel="stylesheet" href="./reset.css"> <link rel="stylesheet" href="./base.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/jquery.slick/1.6.0/slick.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/jquery.slick/1.6.0/slick-theme.css"> <link rel="stylesheet" href="./common.css"> <link rel="stylesheet" href="./top.css"> <link rel="stylesheet" href="./sample.css"> </head> <body> <main> <div class="top_title_container"> <div class="top_title_name"> <span class="top_title_main_name">aaaaaaaaaaaaaaaaa</span> </div> </div> </main> </body> </html>
.top_title_main_name{ font-size: 72px; color: #FFD700; text-align: left; font-family: serif; } .top_title_main_name:before{ content: "bbbbbbbbbbbbbbbbbbbbbbb"; display: block; font-size: 24px; font-weight: bold; font-family: serif; color: #330000; text-align: left; margin-bottom: -16px }

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

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

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

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

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

kei344

2017/09/18 01:32

書かれている状況が再現するコード(HTML/CSS)を提示されたほうが回答を得やすいと思います。
tokyodesk

2017/09/18 02:10

ご回答ありがとうございます。先ほどコードを記載しました。
kei344

2017/09/18 02:13

もしかして質問内容をエディタで作ってコピー&ペースしていませんか?teratail のバグで記述内容が表示されないというものが以前有ったので、ペースト後に何文字か記入してみてください。
tokyodesk

2017/09/18 02:38

失礼しました。変更概要を空白にしたため「更新する」を押しても反映されなかったようです。本題なのですが、自分で検証してみたところ文字フォントサイズが大きいのが原因のようです。これは疑似要素は関係なく、HTMLの仕様で仕方がない現象なのでしょうか。またマイナスマージンで調整しようと思っているのですが、これは適切な対処方法なのでしょうか。
kei344

2017/09/18 02:42

CSSが提示されていませんので、状況を再現できません。また、「testetstetest」など不要な記述が残っているようです。記入エリアの右部分あたりにリアルタイムに結果が表示されていると思うので、そこを見ながら調整してください。
tokyodesk

2017/09/18 02:48

何度もすみません。CSSを加えて修正しました。お願いします。
guest

回答2

0

ベストアンサー

aaaaaaaaaaaaaaaaa ではなく AAAAAAAAAAA とかにすればわかると思いますが、「空白」というより文字の高さの問題では。「Aa」と並べて「a」のほうが低いですよね?

ブラウザ(というよりOS)で表示される文字には高さがあり、文字種によっては空間(「a」の上とか)が設定されています。

【基本的なルール | typetuto.jp】
http://typetuto.jp/basic

  1. 仮想5本線と文字の高さ

上記サイトの画像のように、高さの種類があり、それはフォントによっても違います。CSSではこれを細かく制御できません。(高さはfont-sizeとline-heightくらいでしか調整できないはず)

投稿2017/09/18 03:30

kei344

総合スコア69407

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

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

tokyodesk

2017/09/19 12:54

そうだったんですね。 助かりました。 何度も手間を取らせてしまって申し訳ありませんでした。 ありがとうございました。
guest

0

ブラウザや検証した環境のOS情報がないとなんとも言えませんが、少なくとも私がsafariブラウザで試したところ、beforeタグを使って空白が追加されることは確認できませんでした。

何かCSSのフレームワークを使用していたりして、他のCSSが効いてしまっているのだと思います。
最小限の構成で試す、resetを上手く使うなどで回避すれば良いと思います。

投稿2017/09/18 00:09

mtdsnsk

総合スコア789

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

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

tokyodesk

2017/09/18 02:11

ご回答ありがとうございます。 コードを記載しました。 調べてみたところ、単純にフォントサイズが大きいために生まれるようです。 これは疑似要素うんぬんではなく、htmlの仕様でしょうか? そしてマイナスマージンで狭めるのは適切な対処方法でしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問