css怎么实现不定宽水平居中


本文摘自PHP中文网,作者青灯夜游,侵删。

方法:1、利用flex布局,将ustify-content和align-items属性都设置为center来实现居中;2、利用transform和position属性来实现居中;3、使用table-cell,利用table的单元格居中效果。

本教程操作环境:Windows7系统、css3版本,该方法适用于所有品牌电脑。

推荐:《css视频教程》

css实现不定宽水平居中

方法1:利用flex

大家的第一反应,可能就是 flex 了。因为它的写法够简单直观,兼容性也没什么问题。是手机端居中方式的首选。

1

2

3

<div class="wrapper flex-center">

    <p>horizontal and vertical</p>

</div>

1

2

3

4

5

6

7

8

9

10

.wrapper {

    width: 300px;

    height: 300px;

    border: 1px solid #ccc;

}

.flex-center {

    display: flex;

    justify-content: center;

    align-items: center;

}

利用到了 2 个关键属性:justify-content 和 align-items,都设置为 center,即可实现居中。

需要注意的是,一定要把这里的 flex-center 挂在父级元素,才能使得其中 唯一的 子元素居中。

方法2:利用transform + position

这个组合,常用于图片的居中显示。

1

2

3

<div class="wrapper">

    <img src="test.png">

</div>

1

2

3

4

5

6

7

8

9

10

11

12

.wrapper {

    width: 300px;

    height: 300px;

    border: 1px solid #ccc;

    position: relative;

}

.wrapper > img {

    position: absolute;

    left: 50%;

    top: 50%;

    transform: translate(-50%, -50%);

}

当然,也可以将父元素 wrapper 的相对定位,移入子元素 img 中,替换掉绝对定位。效果是一样的。

方法3:table-cell

利用 table 的单元格居中效果展示。与 flex 一样,需要写在父级元素上。

1

2

3

<div class="wrapper">

    <p>horizontal and vertical</p>

</div>

1

2

3

4

5

6

7

8

.wrapper {

    width: 300px;

    height: 300px;

    border: 1px solid #ccc;

    display: table-cell;

    text-align: center;

    vertical-align: middle;

}

方法4:grid

像表格一样,网格布局让我们能够按行或列来对齐元素。 然而在布局上,网格比表格更可能做到或更简单。

1

2

3

<div class="wrapper">

    <p>horizontal and vertical</p>

</div>

1

2

3

4

5

6

7

8

9

10

.wrapper {

    width: 300px;

    height: 300px;

    border: 1px solid #ccc;

    display: grid;

}

.wrapper > p {

    align-self: center;

    justify-self: center;

}

但它在兼容性上不如 flex,特别是 IE 浏览器,只支持 IE10 及以上。

更多编程相关知识,请访问:编程入门!!

以上就是css怎么实现不定宽水平居中的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

css的font字体颜色如何设置

css中有哪些字体属性

css怎么实现实现宽高比

css如何将图片等比缩放

如何在css上让图片居中、图片适应

css的基本语法是什么

css td文字不换行如何实现

css box-direction属性怎么用

css怎么设置滚动条宽度

css每条声明由一个什么组成

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...