2

我目前正在设计一个带有 em 单位的网页。我想我并没有像我想象的那样理解它,因为在我尝试将两个单独的 span 标签与 margin-left 对齐时出现了问题。它们被放置在我标题的左上角。使用 display:block 将它们放置在彼此之上。当我使用 margin-right 来对齐 span 标签时,较大的 span 和较小的标签没有正确对齐。我使用相同的数字作为margin-right,但它们仍然搞砸了。

  • 这是因为我使用的是 em 的吗?
  • 我怎样才能解决这个问题?

我将在下面粘贴我正在使用的代码,以便您了解我正在使用什么。希望我已经解释得足够好。

HTML

    <div class="header1">
      <span class="title">Title goes here</span>
      <span class="subtitle">This is the subtitle</span>
    </div>

CSS

body {
    color: #333;
    font-family: 'lucida grande', tahoma, verdana, arial, sans-serif;
    font-size: 62.5%; /* 10px */
    line-height: 1.28;
}
.main1 {
  width: 96em;
  /* horizontally center the website layout */
  margin: 0 auto; margin-top: .8em;
  text-Align: left; /* override body {text-align:center} */
}
div.header1 {
  clear: both;
  width: 100%;
  height: 9em;
  background: #ff0000;
  color: #fff;
}
.title {
  font: small-caps 700 3.7em "Goudy Old Style", Garamond, "Big Caslon", "Times New Roman", serif;
}
.subtitle {
  font-weight: lighter;
  font-size: 1.4em;
}
4

3 回答 3

2

问题的描述非常混乱,并没有解释您想要实现的目标以及您最好的尝试是什么。您指的是左右边距,但它们都没有在您的代码中为所讨论的元素设置。您指的是设置display: block,但没有这样的设置。

我假设您希望主标题出现在副标题上方(在 xy 平面上)。为此,您需要设置display: block或者更好地使用div标记来代替,span或者最好使用适当的标题标记,例如h1h2适当考虑它们对垂直边距和字体粗细的默认影响(即,如果需要,在 CSS 中覆盖它们)。而且我假设您希望它们左对齐相同的数量。

看来您没有考虑em单位的相对性。根据定义,它等于元素的字体大小(在 中除外font-size,它等于父元素的字体大小)。

我怀疑您尝试span使用相同的值设置两个元素的左边距,例如1em. 但这两个元素的含义并不相同,因为它们的em大小不同。如果你想将它们的左边距设置为第一个元素的字体大小,你可以设置

.title { margin-left: 1em; }
.subtitle { margin-left: 2.6429em; }

该数字2.6429是字体大小的比率,由 3.7/1.4 计算得出。

div在封闭元素上设置左边距会更容易。它的字体大小等于body元素的字体大小,所以如果你想将它设置为主标题的字体大小,你可以使用

div.header1 { margin-left: 3.7em; }
于 2012-12-01T08:40:52.220 回答
0

检查下面的链接我希望这对你有帮助

http://kyleschaeffer.com/best-practices/css-font-size-em-vs-px-vs-pt-vs/

于 2012-12-01T06:04:58.097 回答
0

px:像素(电脑屏幕上的一个点)

em: 1em 等于当前字体大小。2em 表示当前字体大小的 2 倍。例如,如果一个元素以 12 pt 的字体显示,那么 '2em' 就是 24 pt。'em' 在 CSS 中是一个非常有用的单位,因为它可以自动适应读者使用的字体。

见参考

因此,您可以改用pxem,这是一种很好的做法。

希望它会帮助你。谢谢。!!

于 2012-12-01T06:55:02.017 回答