欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

在CSS網格中居中

林雅南2年前8瀏覽0評論

我試圖用CSS網格創建一個簡單的頁面。

我沒有做到的是將HTML中的文本集中到相應的網格單元格中。

我嘗試過將內容放在left_bg和right_bg選擇器內外的獨立div中,并嘗試了一些CSS屬性,但沒有成功。

我該怎么做?

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  display: subgrid;
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
}

.right_bg {
  display: subgrid;
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
}

.left_text {
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  position: relative;
  z-index: 1;
  justify-self: center;
  font-family: Raleway;
  font-size: large;
}

.right_text {
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  position: relative;
  z-index: 1;
  justify-self: center;
  font-family: Raleway;
  font-size: large;
}

<div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
  </div>
</div>

<div class="right_bg">
  <!--right background color of the page-->
</div>

<div class="left_text">
  <!--left side text content-->
  <p>Review my stuff</p>

  <div class="right_text">
    <!--right side text content-->
    <p>Hire me!</p>
  </div>
</div>

這個答案有兩個主要部分:

理解CSS網格中的對齊方式。 CSS網格中居中的六種方法。 如果你只對解決方案感興趣,跳過第一部分。

網格布局的結構和范圍 要完全理解網格容器中的居中方式,首先理解網格布局的結構和范圍是很重要的。

網格容器的HTML結構有三個層次:

集裝箱 該項目 內容 就應用網格屬性而言,每個級別都獨立于其他級別。

網格容器的范圍僅限于父子關系。

這意味著網格容器總是父容器,網格項目總是子容器。網格屬性僅在這種關系中有效。

子容器之外的網格容器的后代不是網格布局的一部分,并且不接受網格屬性。(至少在實現子網格特性之前不會,這將允許網格項目的后代尊重主容器的行。)

這里有一個上面描述的結構和范圍概念的例子。

想象一個井字游戲般的網格。

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
}

enter image description here

您希望X和O在每個單元格中居中。

因此,您在容器級別應用居中:

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
}

但是由于網格布局的結構和范圍,容器上的justify-items使網格項居中,而不是內容居中(至少不是直接居中)。

enter image description here

article {
  display: inline-grid;
  grid-template-rows: 100px 100px 100px;
  grid-template-columns: 100px 100px 100px;
  grid-gap: 3px;
  justify-items: center;
}

section {
    border: 2px solid black;
    font-size: 3em;
}

<article>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
    <section>O</section>
    <section>X</section>
</article>

甚至不要嘗試使用flex,繼續使用css grid。只需在內容元素上添加以下內容:

place-self: center;

它會在這里做定心工作。

如果你想讓網格單元內的div居中,你需要定義嵌套網格來使它工作。 演示中顯示了這兩個示例。

https://css-tricks.com/snippets/css/complete-guide-grid/

CSS place-items速記屬性分別設置align-items和justify-items屬性。如果沒有設置第二個值,則第一個值也用于它。

.parent {
  display: grid;
  place-items: center;
}

您可以使用flexbox將文本居中。順便說一句,不需要額外的容器,因為文本被認為是匿名的彈性項目。

來自flexbox規格:

flex容器的每個流入子元素都成為一個flex項目,而直接包含在flex容器中的每個連續文本都包裝在一個匿名flex項目中。但是,僅包含空白(即,受空白屬性影響的字符)的匿名flex項目不會呈現(就像它顯示:none一樣)。

因此,只需將網格項作為flex容器(display: flex),并添加align-items: center和justify-content: center以垂直和水平方向居中。

還對HTML和CSS進行了優化:

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  
  font-family: Raleway;
  font-size: large;
}

.left_bg,
.right_bg {
  display: flex;
  align-items: center;
  justify-content: center;
}

.left_bg {
  background-color: #3498db;
}

.right_bg {
  background-color: #ecf0f1;
}

<div class="container">
  <div class="left_bg">Review my stuff</div>
  <div class="right_bg">Hire me!</div>
</div>

我們可以用方位詞:center屬性使子元素文本居中。

.parent {
    display:grid;
    grid-template-columns: repeat(2,1fr);
    border: 3px solid yellow;
    grid-gap: 3px;
    place-items: center;
 }
 
 .parent > div {
    background-color: blue;
    text-align: center;
    color: white;
    font-weight: bold;
    font-size: 2rem;
 }

<div class="parent">
  <div class="child1">child1</div>
  <div class="child2">child2</div>
</div>

使父網格和justify-content:center;和align-content:居中;

.parent {
  height: 100px;
  width: 100px;
  border: 1px solid black;
  display: grid;
  justify-content: center;
  align-content: center;
}

.child {
  height: 20px;
  width: 20px;
  background-color: red;
}

<div class="parent">
  <div class="child">child</div>
</div>

嘗試使用flex:

普蘭克演示:https://plnkr.co/edit/nk02ojKuXD2tAqZiWvf9

/* Styles go here */

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;

}

.right_bg {
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.text {
  font-family: Raleway;
  font-size: large;
  text-align: center;
}

超文本標記語言

<div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
    <div class="text">
      <!--left side text content-->
      <p>Review my stuff</p>
    </div>
  </div>

  <div class="right_bg">
    <!--right background color of the page-->
    <div class="text">
      <!--right side text content-->
      <p>Hire me!</p>
    </div>
  </div>
</div>

這對我很有效:

.d-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid black;
  border-left: 1px solid black;
}

.d-grid div {
  height: 50px;
  display: flex;
  border-bottom: 1px solid black;
  border-right: 1px solid black;
  align-items: center;
  justify-content: center;
}

<div class="d-grid">
  <div>text 1</div>
  <div>text 2</div>
  <div>text 3</div>
  <div>text 4</div>
  <div>text 5</div>
  <div>text 6</div>
</div>

你想要這個?

html,
body {
  margin: 0;
  padding: 0;
}

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 100vh;
  grid-gap: 0px 0px;
}

.left_bg {
  display: subgrid;
  background-color: #3498db;
  grid-column: 1 / 1;
  grid-row: 1 / 1;
  z-index: 0;
}

.right_bg {
  display: subgrid;
  background-color: #ecf0f1;
  grid-column: 2 / 2;
  grid_row: 1 / 1;
  z-index: 0;
}

.text {
  font-family: Raleway;
  font-size: large;
  text-align: center;
}

<div class="container">
  <!--everything on the page-->

  <div class="left_bg">
    <!--left background color of the page-->
    <div class="text">
      <!--left side text content-->
      <p>Review my stuff</p>
    </div>
  </div>

  <div class="right_bg">
    <!--right background color of the page-->
    <div class="text">
      <!--right side text content-->
      <p>Hire me!</p>
    </div>
  </div>
</div>