Heim > Web-Frontend > CSS-Tutorial > Die dunkle Magie der CSS-Inline-Ausrichtung

Die dunkle Magie der CSS-Inline-Ausrichtung

高洛峰
Freigeben: 2016-11-07 17:52:54
Original
988 Leute haben es durchsucht

Orange versucht sein Bestes, um mit Ihnen zu teilen, wie Sie die Fallstricke in tatsächlichen Projekten beseitigen können. Es gibt viele Methoden und willkommene Diskussionen. Außerdem ist es nicht besonders freundlich für Neulinge Das Frontend spielt keine Rolle. Für Anleitungen, Links oder Tipps können Sie Google (Baidu) verwenden.


Wenn es um die Inline-Ausrichtung geht, denken Sie vielleicht an Artikel, die der horizontalen Ausrichtung und der vertikalen Ausrichtung ähneln. Da wir es Black Magic nennen, handelt es sich nicht um ein grundlegendes Ausrichtungs-Tutorial , ein grundlegendes Tutorial. Es gibt viele Artikel, und jeder muss wissen, dass es viele Möglichkeiten gibt, eine Ausrichtung zu erreichen

Projekthintergrund

Es ist auch ein Handy Projekt von Oranges Unternehmen, die Fallstudie

Die dunkle Magie der CSS-Inline-Ausrichtung

Schauen wir uns nur die erste Textzeile an, die der Titel jedes Tages ist. TMD, willst du mich veräppeln? Wenn es dazu etwas zu sagen gibt, kann es jeder schreiben!

Regen Sie sich nicht auf, wie man dieses Layout implementiert. Schauen Sie sich weiterhin den vorläufigen Implementierungscode an Der Screenshot sieht wie folgt aus:

<div class="date-wrap">
  <span class="date">14 OCT</span>
  <span class="multiple">x</span>
  <span class="desc">今日瞎选6篇</span>
</div>

<style type="text/css">
  .date-wrap {
    width: 100%;
    height: 60px;
    position: relative;

    text-align: center;
    line-height: 60px;

    font-size: 18px;
    font-weight: 600;
  }

  .multiple {
    color: #f8ac08;
  }
</style>
Nach dem Login kopieren

Aufmerksame Freunde können das Problem erkennen. Es macht nichts, wenn Sie es nicht sehen können. Die dunkle Magie der CSS-Inline-Ausrichtung

Der Effekt ist wie folgt

<div class="date-wrap">
  <span class="date">14 OCT</span>
  <span class="multiple">x</span>
  <span class="desc">今日瞎选6篇</span>
  <div class="line-top"></div>
  <div class="line-bottom"></div>
</div>

<style type="text/css">
  /* 这里是前面的样式,不重复给出 */
  .line-top {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    top: 21px;

    background-color: #000;
  }

  .line-bottom {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 21px;

    background-color: #000;
  }
</style>
Nach dem Login kopieren

Okay, ich glaube, jetzt kann jeder das Problem auf einen Blick erkennen, das heißt, das vorherige Datum ist nicht vertikal zentriert Was ist der Grund? Auch die Erklärung ist einfachDie dunkle Magie der CSS-Inline-Ausrichtung

Sie müssen hier nur eine Codezeile ändern, um Ihre Fragen zu beantworten

Nachdem Sie den entsprechenden HTML-Code oben geändert haben, erhalten Sie den Screenshot

<span class="date">14 OCT orange</span>
Nach dem Login kopieren

Das erinnert mich an das vierzeilige Raster in den englischen Hausaufgabenbüchern der Grundschule, haha. Die Großbuchstaben stehen tatsächlich in den beiden Rastern oben, und es gibt Beispiele für Kleinbuchstaben im oberen , Mittel- und Kleinschreibung allein, es ist leicht zu erklären. Die dunkle Magie der CSS-Inline-Ausrichtung

Dieser scheinbar einfache Fall ist so besonders. Wenn Sie vorsichtig sind, werden Sie feststellen, dass es am Ende auch ein Problem mit der 6 gibt. Es ist nicht zentriert. Ich war so verwirrt, dass ich es in der Mitte geschrieben habe, aber es kann nicht gelöst werden.

Nein, wir werden dieses Problem als nächstes lösen. Erfahrene Frontends kennen die Unterschiede zwischen den einzelnen Schriftarten und danach sind unterschiedlich, aber glücklicherweise ist der Unterschied in der vertikalen Richtung nicht sehr groß. Hier habe ich die ursprüngliche Schriftart des Projekts vorgestellt, und das x in der Mitte ist eigentlich eine SVG-Datei, auf die ich hier nicht näher eingehen werde. Denn wenn du deine Gedanken verstehst, kannst du problemlos hunderte Fehlstellungen lösen.

Betreten Sie die wahre Zauberwelt. Sie können selbst auswählen

Keine Schritt-für-Schritt-Erklärung. Gehen Sie einfach direkt zu dem Problem, das gelöst wurde. Der Code

hat folgenden Effekt:

Toll, ich habe nur die Schriftgröße geändert des folgenden Textes: 16px; Das Problem ist gelöst, ich bin froh, dass ich es zum Designer gebracht, verglichen und überarbeitet habe,
<div class="date-wrap">
  <div class="date">14 OCT</div>
  <div class="multiple">x</div>
  <div class="desc">今日瞎选6篇</div>
  <div class="line-top"></div>
  <div class="line-bottom"></div>
</div>

<style type="text/css">
  @font-face {
    font-family: century-gothic-bold;
    src: url(&#39;century-gothic-bold.ttf&#39;);
  }

  @font-face {
    font-family: FZYouH_512B;
    src: url(&#39;FZYouH_512B.ttf&#39;);
  }

  .date-wrap {
    width: 100%;
    height: 60px;
    display: flex;
    position: relative;

    flex-direction: row;
    align-items: center;
    justify-content: center;

    text-align: center;
    line-height: 60px;

    font-size: 18px;
    font-weight: 600;
  }

  .date {
    font-family: century-gothic-bold;
  }

  .multiple {
    margin: 0 10px;
    color: #f8ac08;
  }

  .desc {
    font-size: 16px;
    font-family: FZYouH_512B;
  }

  .line-top {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    top: 22px;

    background-color: #000;
  }

  .line-bottom {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 22px;

    background-color: #000;
  }
</style>
Nach dem Login kopieren

Was zum Teufel? Was zum Teufel? Zehntausend Grasschlammpferde (Fabelwesen) galoppieren in meinem Herzen vorbei, schau genau hin! Die Augen weiteten sich. . . . Das ist richtig

Unsere Hilfslinien erscheinen über dem Wort „Jiu“. Der Designer macht auch einen Screenshot des Mobiltelefons und vergleicht die Hilfslinien mit dem Originalmanuskript~Die dunkle Magie der CSS-Inline-Ausrichtung

Die Lösung ist durchaus einfach, einfach

Fügen Sie einfach eine Zeile hinzu, Dang Dang Dang~

.desc {
  margin-top: 1px;  /* add */

  font-size: 16px;
  font-family: FZYouH_512B;
}
Nach dem Login kopieren

嗑嗑,凑合这样吧,为什么?明明对齐了啊!再仔细看,我是认真的,没玩大家,发现我们的 date 低了不到一个像素(使用 Retina 屏幕的朋友看的明显些),有人问一像素以内可以调整嘛?明确告诉大家可以,之后的文章准备做解释,这里不展开

第一种方案到这为止,上手试验的朋友虽然没有我的字体,你不必去下载,浏览器默认字体一样的,我们讲的是原理,没必要还原我的 demo,关键就是 block 元素的上下 margin 调整。

提醒:这里的 margin 可以设置负值,如果负值无用自己去探索原因吧,给大家线上项目的控制台

Die dunkle Magie der CSS-Inline-Ausrichtung

我这里给的就是负值,是有作用的哦,可以去 敢玩移动端主页,记得在模拟器里查看(不然会乱成一锅粥),控制台一看便知,不过多解释啦。

vertical-align 魔法

完整代码如下

<div class="date-wrap">
  <span class="date">14 OCT</span>
  <span class="multiple">x</span>
  <span class="desc">今日瞎选6篇</span>
  <div class="line-top"></div>
  <div class="line-bottom"></div>
</div>

<style type="text/css">
  @font-face {
    font-family: century-gothic-bold;
    src: url(&#39;century-gothic-bold.ttf&#39;);
  }

  @font-face {
    font-family: FZYouH_512B;
    src: url(&#39;FZYouH_512B.ttf&#39;);
  }

  .date-wrap {
    width: 100%;
    height: 60px;
    position: relative;

    text-align: center;
    line-height: 60px;

    font-size: 18px;
    font-weight: 600;
  }

  .date {
    font-family: century-gothic-bold;
  }

  .multiple {
    color: #f8ac08;
  }

  .desc {
    vertical-align: 1px;

    font-size: 16px;
    font-family: FZYouH_512B;
  }

  .line-top {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    top: 22px;

    background-color: #000;
  }

  .line-bottom {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 22px;

    background-color: #000;
  }
</style>
Nach dem Login kopieren

以上代码运行效果和之前一摸一样这里就不一一截图费大家流量啦(良心前端。。。。)

和上一个方法区别在于我们行内元素还用之前的 span 标签。然后通过 vertical-align: 1px; 来调节垂直方向上下的位置。对这个属性不熟悉的朋友可以去看MDN的文档:https://developer.mozilla.org...

几种语法如下

/* keyword values */
vertical-align: baseline;
vertical-align: sub;
vertical-align: super;
vertical-align: text-top;
vertical-align: text-bottom;
vertical-align: middle;
vertical-align: top;
vertical-align: bottom;

/* <length> values */
vertical-align: 10em;
vertical-align: 4px;

/* <percentage> values */
vertical-align: 20%;

/* Global values */
vertical-align: inherit;
vertical-align: initial;
vertical-align: unset;
Nach dem Login kopieren

我们用的这个  values 长度单位实际应用较少,却是行内元素垂直对齐的黑魔法。不了解的不要紧,赶快 get 新技能

总结

两种方案都可行,有时候不要因为一像素绞尽脑汁,找到突破口,以后谁还会怕行内对齐了呢?


Verwandte Etiketten:
css
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage