伪元素在父元素中居中_web前端Html5开发CSS之元素五大居中方式,实用又简单!...

954d7a8cfab36abd4ad059d00125c3cf.png

大家是不是对元素居中的知识点很是模糊?是不是苦于找不到一个总结的通俗易懂的说明?是不是自己懒得去总结?今天小编在前端的学习与实践中总结出的元素的五大居中方式,黏贴了代码并对代码做了解释,希望对迷茫的有所帮助!

下面的居中示例中,统一使用了同一个div作为父元素和p作为子元素

设置一个div,并且设置了div的宽高边框,div里面设置一个块元素p,设置了它的宽高和背景色

css居中方式1

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>五大居中1</title>

<style>

*{margin:0;}

div{width:200px;height:300px;border:2px solid #000;margin:200px auto;

text-align:center;font-size:0;

}

div p{width:100px;height:100px;background:#666;

display:inline-block;vertical-align:middle;

}

div:after{content:"";display:inline-block;height:100%;vertical-align:middle;}

</style>

</head>

<body>

<div>

<p></p>

</div>

</body>

</html>

87c8066b90c9d398ae41095acdc8b857.png

这里利用了伪元素让子元素p在div盒子里左右水平居中只需要在它的父元素div里加text-align:center;垂直方向居中需要在父元素后面加了一个伪元素,并使得样式为inline-block;height:100%;就是和父元素一样高,vertical-align:middle;垂直居中,也就是p元素相对与伪元素居中,由于伪元素和div一样高,所以相当于p元素在div里垂直居中。

css居中方式2

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>五大居中2</title>

<style>

*{margin:0;}

div{position:relative;width:300px;height:400px;border:1px solid #000;margin:100px auto;}

p{position:absolute;left:0;bottom:0;right:0;top:0;margin:auto;width:100px;height:100px;background:#f99;}

</style>

</head>

<body>

<div>

<p></p>

</div>

</body>

</html>

这里利用了定位居中

子元素p设置position:absolute脱离文档流,默认以html作为父元素,所以我们给父元素div设置position:relative;使得p以div为父元素做位置的变动,left:0;tight:0;top:0;bottom:0;(只有设置了定位的元素才可以使用这种方式来移动),最后margin:auto;就会水平和垂直都居中。

css居中方式3

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>五大居中3</title>

<style>

*{margin:0;}

div{display:flex;justify-content:center;align-items:center;width:300px;height:400px;border:1px solid #000;margin:100px auto;}

p{width:100px;height:100px;background:#f99;}

</style>

</head>

<body>

<div>

<p></p>

</div>

</body>

</html>

e2e864a8f630ae30eb9273d48dd24a87.png

这里利用了弹性盒居中

父元素div设置成弹性盒样式,justify-content:center;主轴居中

align-items:center;垂直居中(而且这两个只能设置在父元素上,弹性盒知识)

css居中方式4

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>五大居中4</title>

<style>

*{margin:0;}

div{position:relative;width:300px;height:400px;border:1px solid #000;margin:100px auto;}

p{width:100px;height:100px;background:#f99;position:absolute;

left:50%;top:50%;margin:-50px 0 0 -50px;}

</style>

</head>

<body>

<div>

<p></p>

</div>

</body>

</html>

利用定位线左上角居中,然后左移子元素宽度的一半,再上移子元素高度的一半。

css居中方式5

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>五大居中5</title>

<style>

*{margin:0;}

div{position:relative;width:300px;height:400px;border:1px solid #000;margin:100px auto;}

p{position:absolute;width:100px;height:100px;background:#f99;left:50%;top:50%;

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

</style>

</head>

<body>

<div>

<p></p>

</div>

</body>

</html>

利用动画移动属性transform

结语

相信看了上面的有关Html5、css的元素五大居中方式,你们就可以解决自己的小问题了,但是也要养成一个总结的好习惯。好记性不如烂笔头!以前留下来的话语总是有他的道理。Come on!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值