我試圖用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;
}
您希望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使網格項居中,而不是內容居中(至少不是直接居中)。
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>