Heim >Web-Frontend >CSS-Tutorial >Was ist CSS-Stacking-Kontext? Was macht es?

Was ist CSS-Stacking-Kontext? Was macht es?

不言
不言nach vorne
2018-10-12 16:44:143195Durchsuche

Der Inhalt dieses Artikels befasst sich mit der Frage, was CSS-Stacking-Kontext ist. Was macht es? Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird Ihnen hilfreich sein.

Was ist CSS-Stacking-Kontext?

Wir haben eine grundlegende Stilabteilung mit dem folgenden Stil:

div{
    width: 200px;
    height: 200px;
    border:10px solid red;
    padding:15px;
    margin:12px;
}

Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Eine Frage hier ist: Welche Beziehung besteht zwischen Grenze und Hintergrund?

Hier gibt es zwei Möglichkeiten:

  1. Parallel

  2. Grenze näher am Benutzer

  3. Hintergrund ist näher am Benutzer

Welches werden Sie wählen?

Tatsächlich ist es sehr einfach, dies zu verstehen. Wir müssen nur den Rand auf halbtransparent stellen, um die Antwort zu erfahren

border:10px solid rgba(255, 0, 0, 0, .3);

Was ist CSS-Stacking-Kontext? Was macht es?

Aus den Laufergebnissen ist ersichtlich, dass Rot vor Grün steht, der Rand also näher am Benutzer liegt. Zu diesem Zeitpunkt wissen Sie, dass das Div nicht flach ist, sondern auch eine hierarchische Beziehung auf dem vertikalen Bildschirm aufweist. Diese hierarchische Beziehung wird dann Stapeln Stapelkontext genannt.

Dann schreiben wir „Hello, world“ in das div, der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Hier stellt sich eine weitere Frage: Auf welcher Ebene befindet sich dieses „Hallo Welt“ an der Grenze oder zwischen der Grenze und dem Hintergrund?

Hier müssen wir nur „Hallo“ an den Rand verschieben, um den Grund zu erfahren. Wie verschiebt man den Text dorthin? Hier verwenden wir text-indent, der Stil ist wie folgt:

div{
  width: 200px;
  height: 200px;
  border:10px solid rgb(255, 0, 0);
  padding:15px;
  margin:12px;
  background-color: green;
  text-indent: -20px;
}

Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Sie können am Laufeffekt erkennen, dass sich der Text über dem Rand befindet, sodass der Textbereich (Inline-Element) näher am Benutzer liegt

Was passiert, wenn sich darin ein weiteres Div befindet? die div? Die Codestruktur ist wie folgt:

 // html
  <div>
    你好,CSS世界
    <div></div>
  </div>
rrree

Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Eine weitere Frage stellt sich, ist der violette Bereich höher als der Textbereich oder umgekehrt?

Wie kann ich dieses Problem überprüfen? Wir müssen nur das darin enthaltene Div nach oben verschieben. Beachten Sie, dass die Position hier nicht verwendet werden kann, da wir zum Ändern der hierarchischen Struktur nur margin-top verwenden müssen, z. B.:

    // css
   .parent{
      width: 200px;
      height: 200px;
      border:10px solid rgb(255, 0, 0);
      padding:15px;
      margin:12px;
      background-color: green;
      text-indent: -20px;
    }
    .child{
      height: 20px;
      background:purple;
    }

Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Sie werden feststellen, dass sich der Textbereich oben befindet. Hier ziehen wir eine Schlussfolgerung:

Wenn es Elemente auf Blockebene im div gibt, können die Elemente auf Blockebene die Inline-Elemente nicht abdecken. Mit anderen Worten, die Inline-Elemente sind näher am Benutzer

Was ist, wenn das Div Text enthält? Zu diesem Zeitpunkt müssen wir ein paar Wörter schreiben. Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Sie werden feststellen, dass der Textbereich des Kindes ist Das Element deckt den Textbereich des übergeordneten Elements ab. Hier gibt es also noch eine kleine Schlussfolgerung: Was nach dem Textbereich erscheint, überschreibt, was davor erscheint.

Floating-Element

Lassen Sie uns eine Grundstruktur haben:

margin-top:-20px;
Der Effekt ist wie folgt:

Was ist CSS-Stacking-Kontext? Was macht es?

Ich werde den obigen Code nicht erklären. Ich bin sicher, dass Sie ihn alle kennen. Gemäß der obigen Routine stellt sich immer noch die gleiche Frage: Sind Sie oben oder in diesem Float-Element besser?

Um dieses Problem zu überprüfen, verwenden Sie auch Texteinzug, um den Text nach links zu verschieben:

Was ist CSS-Stacking-Kontext? Was macht es?

Aus der Darstellung

können wir schließen, dass sich der Textbereich über dem schwebenden Wolkenelement befindet.

那浮动元素是在 文字区域与内部块级元素之间呢,还是内部块级与border元素之间呢?换句话说就是 浮动元素与块级元素哪个离用户更近?

我们直接在父级元素写一个 child:

    // hmtl
  <div>
      你好
    <div></div>
    <div></div>
  </div>

  // css
  
 .child{
  height: 20px;
  background: black;
}

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

从上可以看出浮云元素盖住了 child元素,说明浮动元素的层级是比块级元素高的。即浮动元素是在文字区域与块级元素之间的。

那浮动元素里面的文字与外面的文字是怎么样的呢?这边我直接在浮动里面加了 float文字,效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

你会发现 浮动里面的文字是盖不住浮动外面文字的。

绝对定位元素

在上面的基础上我们增加一个 relative 元素,如下:

  // htmk
  <div>
      你好
    <div>floatt</div>
    <div></div>
    <div></div>
  </div>
  
 // css
.relative{
  width: 100px;
  height: 100px;
  background: pink;
  margin-top: -15px;
}

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

这时我们给类relative 加上一个:

position:relative;

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

你会发现 relative 元素盖住了浮动元素,这说明 给元素加一个 relative 定位会增加对应的一个层级。检查 relative 元素,会看到:

Was ist CSS-Stacking-Kontext? Was macht es?

加了 position:relative定位会多了一个 z-index:auto 的东西,实际上你定位,都是按z-index来计算的。

这里我们给没有定位的 child元素加上一个z-index:

  <div>
      你好
    <div>floatt</div>
    <div></div>
    <div></div>
  </div>

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

你会发现 child 元素并没有盖住 relative 元素!

这边直接 给了结论了:z-index 只有在 position:relative|absolute
才有效果,如果都是relative,z-index一样,那么后面会盖前面,z-index值大的会盖住小的。

我们接着在原有上加一个relative2,样式如下:

.relative2{
  width: 100px; 
  height: 150px;
  background: gold;
  margin-top: -15px;
  position: relative;
}

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

此时给 relative2 加上一个 z-index:-1,在看

Was ist CSS-Stacking-Kontext? Was macht es?

又得出一个结论:z-index为负值时,是位于 background下面的

这时,我们给.parent元素添加以下两个样式:

  position: relative;
  z-index: 0;

这时的效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

这时奇怪的事情就出现了,z-index: -1 的跑到上面来了。

MDN上有对什么堆叠给出了一些内容,如下 :

Was ist CSS-Stacking-Kontext? Was macht es?

其实我们给.parent元素设置z-index:0 ,根据MDN说的,我们其实已经 创造一个层叠上下文 。

那什么是堆叠上下文?下面是张鑫旭一段原文:

Was ist CSS-Stacking-Kontext? Was macht es?

其实这跟美国一个大法官说的一句话很像:我不知道什么色情,但当我看到它是我就知道什么是色情。

CSS堆叠上下文也是类似的道理,你很难说出什么是CSS堆叠上下文,但只要它满足MDN列出的几种情况,它就是CSS堆叠上下文。

CSS堆叠层叠顺序

CSS堆叠上下文是有一个垂直屏幕上有一个上关系的,它们的关系如下:

Was ist CSS-Stacking-Kontext? Was macht es?

所以这就解释为什么z-index为负值的时候,它会在 background上面,因为我们 z-index:0 时就创建一个CSS堆叠上下文。

CSS堆叠上下文作用

下面给一个基本的内容:

   // html
  <div>
    <div>a
      <div>a1</div>
    </div>
    <div>b
      <div>b1</div>
    </div>
  </div>
  // css
 .parent{
  width: 200px;
  height: 200px;
  border:10px solid rgb(255, 0, 0);
  padding:15px;
  margin:12px;
  background-color: green;
}
.relative{
  width:100px;
  height:100px;
  background: orange;
  position: relative;
  border:1px solid red;
}
.a1{
  position: relative;
  background:green;
}
.b1{
  position: relative;
  background:red;
}

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

接着我们在b1在添加以下样式:

   margin-top: -90px;

Was ist CSS-Stacking-Kontext? Was macht es?

b1会盖住a1,这个我们应该知道是什么原因了吧?因为a1 b1都是块级元素,后面会盖住前面的,没毛病!

那么 a1 和  b1 的CSS堆叠上下文是谁?

我们可以MDN给出的第一句:

Was ist CSS-Stacking-Kontext? Was macht es?

根元素,所以a1 和 b1的CSS堆叠上下文就是Html

接着给a1以下样式:

   z-index: 2;

接着给b1以下样式:

z-index: 0;

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

a1跑到b1上面了,这个很好理解,因为 a1 的z-index:2 比 b1的z-index:0 在,所以a1在上面。

现在有一个问题,a1是永远盖住b1吗?

这边你可能会说,a1 的z-index:2比 b1的 z-index:0 永远都大,当然会盖住b1呀!是这样吗?我们试着改变一下CSS堆叠上下文。

我们分别给a 和 b各做一个CSS堆叠上下文: 如下:

.a{
  position: relative;
  z-index: 1;
}
.b{
  position: relative;
  z-index: 1;
}

效果如下:

Was ist CSS-Stacking-Kontext? Was macht es?

先分析a 和 b它们是谁覆盖谁,因为 两个定位和z-index都一样所以 b 会覆盖 a。还有一个现象有没有发现, b1 盖住了 a1? 明明 a1 的 z-index 大于 b1,这是为什么?为什么小的会盖住大的?为什么?

因为 b 比 a 高一点,所以 b 里面的内容都会比 a 高一点。这就是 CSS堆叠上下文一个特性。

比如说阿里巴巴有一个奇怪的部门叫做政委,是由马云等一些创始人组成的。在这个部门里面,你是不是都比其它部门要高级点。

所以 b1 虽然在 b 里面等级为0,在 b 是高级的一个部门,就是可以压过你 a 这个部门里面的 2 级的人。

Das obige ist der detaillierte Inhalt vonWas ist CSS-Stacking-Kontext? Was macht es?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen