最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

css水平垂直居中的方法总结

来源:懂视网 责编:小采 时间:2020-11-27 18:53:08
文档

css水平垂直居中的方法总结

css水平垂直居中的方法总结:在项目中经常会遇到设置元素水平垂直居中的需求。而且具体的场景也不同,所以将个人总结的方法做个汇总,希望对浏览者有用。以下所举的例子都以一个html为准,这里规定好一些公用样式。body { background-color: #efefef; } main { backgro
推荐度:
导读css水平垂直居中的方法总结:在项目中经常会遇到设置元素水平垂直居中的需求。而且具体的场景也不同,所以将个人总结的方法做个汇总,希望对浏览者有用。以下所举的例子都以一个html为准,这里规定好一些公用样式。body { background-color: #efefef; } main { backgro
在项目中经常会遇到设置元素水平垂直居中的需求。而且具体的场景也不同,所以将个人总结的方法做个汇总,希望对浏览者有用。
以下所举的例子都以一个html为准,这里规定好一些公用样式。

body {
 background-color: #efefef; 
}
main {
 background-color: #fff;
 padding: 10px;
 margin:10px 0px;
}
main p {
 background-color: #aaf;
}

水平居中

1 相对块级父元素,可将子级设置成行内或者行内块元素,父元素设置text-align属性

举例如下:

.parent1 {
 text-align:center;
}
.child1 {
 display:inline|inline-block;
}

2 若父子都为块级元素,则给子元素宽度值之后,将margin:auto

<main class="parent2">
 <p class="child2">我是孩子2,我要水平居中</p>
</main>
.child2 {
 width:60%;
 margin:auto;
}

3 如果是多个子元素水平居中,则有两种方法

3.1 将子级设置成行内或者行内块元素,父元素设置text-align属性
3.2 将父元素设置display:flex
<main class="parent4">
 <p class="child4">我是孩子4,我要水平居中</p>
 <p class="child4">我是孩子4,我要水平居中</p>
 <p class="child4">我是孩子4,我要水平居中</p>
</main>

.parent4 {
 display: flex;
 justify-content: center;
}
 .child4 {
 margin:10px;
}

垂直居中

1 除了设置固定的padding值使其看起来垂直居中之外,还可用line-height

将line-height和height的值设置为相同值,

<main class="parent5">
 <p class="child5">我是孩子5,我要垂直居中</p>
</main>
.child5 {
 height:50px;
 line-height: 50px;
}

2 如果是多行的,可以像table那样,按照table cell 模式显示,配合vertical-align

<main class="parent6">
 <p class="child6">我是孩子6,我要垂直居中</p>
 <p class="child6">我是孩子6,我要垂直居中</p>
 <p class="child6">我是孩子6,我要垂直居中</p>
</main>
.parent6 {
 display: table;
}
.child6 {
 display: table-cell;
 border:2px solid #000;
 vertical-align: middle;
}

3 通过绝对定位

<main class="parent7">
 <p class="child7">我是孩子7,我要垂直居中</p>
</main>
/*如果知道子元素宽高*/
.parent7 {
 position: relative;
 height: 100px;
}
.child7 {
 position: absolute;
 top:50%;
 height:60px;
 margin-top:-30px;
}
/*如果不知道子元素宽高*/
.parent7 {
 position: relative;
 height: 100px;
}
.child7 {
 position: absolute;
 top:50%;
 transform: translateY(-50%);
}

4 使用flex

<main class="parent8">
 <p class="child8">我是孩子8,我要垂直居中</p>
</main>
.parent8 {
 height: 200px;
 display: flex;
 flex-direction: column;
 justify-content: center;
}

水平和垂直都居中

1 使用绝对定位

<main class="parent9">
 <p class="child9">我是孩子9,我要水平垂直居中</p>
</main>
 /*如果不知道子元素宽高*/
.parent9 {
 position: relative;
 height: 150px;
}
.child9 {
 position: absolute;
 top:50%;
 left:50%;
 transform: translate(-50%,-50%);
}
/*如果知道子元素宽高*/
.parent9 {
 position: relative;
 height: 150px;
}
.child9 {
 position: absolute;
 top:50%;
 left:50%;
 height:60px;
 width:100px;
 margin-left:-50px;
 margin-top:-30px;
}

2 使用flex

.parent10 {
 height: 200px;
 display: flex;
 flex-direction: column;
 justify-content: center;
}
.child10 {
 margin: auto;
}

3 除此之外,还可以将上述的水平和垂直分别居中的方法,尝试着搭配。当然,应该还有其它方法,待发现。

上述结果输出截图

css 水平垂直居中的方法总结
css 水平垂直居中的方法总结

更多css 水平垂直居中的方法总结相关文章请关注PHP中文网!

文档

css水平垂直居中的方法总结

css水平垂直居中的方法总结:在项目中经常会遇到设置元素水平垂直居中的需求。而且具体的场景也不同,所以将个人总结的方法做个汇总,希望对浏览者有用。以下所举的例子都以一个html为准,这里规定好一些公用样式。body { background-color: #efefef; } main { backgro
推荐度:
标签: 方法 居中 汇总
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top