《Web开发中让盒子居中的几种方法》

一、记录下几种盒子居中的方法:

1.0、margin固定宽高居中;

2.0、负margin居中;

3.0、绝对定位居中;

4.0、table-cell居中;

5.0、flex居中;

6.0、transform居中;

7.0、不确定宽高居中(绝对定位百分数);

8.0、button居中。

 

二、代码演示(html使用同一个Demo):

html Demo:

<body>    <div id="container">        <div id="box"></div>    </div></body>

登录后复制

 

1.0、margin固定宽高居中(演示)

这种定位方法纯粹是靠宽高和margin拼出来的,不是很灵活。

CSS:

#container {    width: 600px;    height: 500px;    border: 1px solid #000;    margin: auto;}#box {    width: 200px;    height: 200px;    margin: 150px 200px;    background-color: #0ff;}

登录后复制

 

2.0、负margin居中(演示)

利用负的margin来进行居中,需要知道固定宽高,限制比较大。

CSS:

#container {    position: relative;    width: 600px;    height: 500px;    border: 1px solid #000;    margin: auto;}#box {    position: absolute;    width: 200px;    height: 200px;    left: 50%;    top: 50%;    margin: -100px -100px;    background-color: #0ff;}

登录后复制

 

3.0、绝对定位居中(演示)

利用绝对定位居中,非常常用的一种方法。

CSS:

#container {    position: relative;    width: 600px;    height: 500px;    border: 1px solid #000;    margin: auto;}#box {    position: absolute;    width: 200px;    height: 200px;    left: 0;    top: 0;    right: 0;    bottom: 0;    margin: auto;    background-color: #0ff;}

登录后复制

 

4.0、table-cell居中(演示)

利用table-cell来控制垂直居中。

CSS:

#container {    display: table-cell;    width: 600px;    height: 500px;    vertical-align: middle;    border: 1px solid #000;}#box {    width: 200px;    height: 200px;    margin: 0 auto;    background-color: #0ff;}

登录后复制

 

5.0、flex居中(演示)

CSS3中引入的新布局方式,比较好用。缺点:IE9以及IE9一下不兼容。

CSS:

#container {    display: -webkit-flex;    display: flex;    -webkit-align-items: center;            align-items: center;    -webkit-justify-content: center;            justify-content: center;    width: 600px;    height: 500px;    border: 1px solid #000;    margin: auto;}#box {    width: 200px;    height: 200px;    background-color: #0ff;} 

登录后复制

 

6.0、transform居中(演示)

这种方法灵活运用CSS中transform属性,较为新奇。缺点是IE9下不兼容。

CSS:

#container {    position: relative;    width: 600px;    height: 600px;    border: 1px solid #000;    margin: auto;}#box {    position: relative;    top: 50%;    left: 50%;    width: 200px;    height: 200px;    transform: translate(-50%, -50%);    -webkit-transform: translate(-50%, -50%);    -ms-transform: translate(-50%, -50%);    -moz-transform: translate(-50%, -50%);    background-color: #0ff;}

登录后复制

 

7.0、不确定宽高居中(绝对定位百分数)(演示)

这种不确定宽高的居中,较为灵活。只需要保证left和right的百分数一样就可以实现水平居中,保证top和bottom的百分数一样就可以实现垂直居中。

CSS:

#container {    position: relative;    width: 600px;    height: 500px;    border: 1px solid #000;    margin: auto;}#box {    position: absolute;    left: 30%;    right: 30%;    top: 25%;    bottom: 25%;    background-color: #0ff;}

登录后复制

 

8.0、button居中(演示)

利用button做外容器,里边的块元素会自动垂直居中,只需要控制一下水平居中就可以达到效果。

HTML:

<button>    <div></div></button>

登录后复制

CSS:

button {    width: 600px;    height: 500px;    border: 1px solid #000;}div {    width: 200px;    height: 200px;    margin: 0 auto;    background-color: #0ff;}

登录后复制

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3119147.html

(0)
上一篇 2025年3月29日 14:26:17
下一篇 2025年3月29日 14:26:32

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论