摘要:怎样让多个元素贴边平分为什么会有这个疑问呢首先说明一下,接触前端有一年的时间了,自认为对静态布局不在话下,果然,自负的人最容易被打脸呐,刚换了一份工作,公司对前端要求比较严格。
怎样让多个元素贴边平分?
为什么会有这个疑问呢?首先说明一下,接触前端有一年的时间了,自认为对静态布局不在话下,果然,自负的人最容易被打脸呐,刚换了一份工作,公司对前端要求比较严格。
公司使用的是bootstrap开发,我们都知道bootstrap框架最核心的是它的栅格系统,我当然也很喜欢这个啦,不过最近UI给我的设计图总是和bootstrap相矛盾,就好比说,有个模块需要每一个元素在移动端和屏幕之间有固定的间距,但是在响应到pc端时,要在有效宽度内贴边对齐。这就很扯淡啦。我画个图表示一下内心的狂躁......
就是实现下面这种结果,看着真的没什么难度,不过因为我是用bs的栅格来布局的,所以需要修改bs的padding的值,这种方法不算明智,所以我思考和汇总了几种实现的做法。都是很基础的。
/* * 怎样让四个没有内边距和边框的元素贴边平分? */ .box{ width: 1170px; margin: 30px auto 0; border:1px solid #00a09d; font-size: 0; } .box>div{ display: inline-block; font-size: 16px; width:23.5%; height: 100px; background: #ffffd; text-align: center; } .box>div:nth-child(n+2){ margin-left:2%; }1234
这个是最基础的,也是最简单的,没什么好说的了,使用最简单的平分宽度实现。效果图:
这个就有意思了,每次在开发过程中,只要设置width+padding+border,问题就接踵而来了。不是元素被挤到下一行,就是这一行的宽度没有平分完。所以我使用了下面的几种方法。
先设置基础样式:
/* * 怎样让四个有没有内边距和边框的元素贴边平分? */ /*基础样式*/ .div-box{ width: 1170px; margin: 30px auto 0; border: 1px solid #000; } .div-box div{ width: 150px; height: 150px; background: #ffffd; padding: 15px; border: 1px solid #000; text-align: center; }1234
居中方式一 : 怪异盒模型+平分宽度
/*居中方式一:怪异盒模型+平分宽度*/ .div-box1 div{ box-sizing: border-box; } .div-box1{ font-size: 0; } .div-box1 div{ display: inline-block; font-size: 16px; width: 23.5%; } .div-box1 div:nth-child(n+2){ margin-left:2%; }
居中方式二:浮动+怪异盒模型+平分宽度
/*居中方式二:浮动+怪异盒模型+平分宽度*/ .div-box2::after{ content: ""; display: block; clear: both; } .div-box2 div{ box-sizing: border-box; float: left; width: 23.5%; } .div-box2 div:nth-child(n+2){ margin-left:2%; }
居中方式三:弹性盒子(用这个最好啦)
/*居中方式三:弹性盒子(用这个最好啦)*/ .div-box3{ display: flex; /*flex-direction:row; //子元素的排列方向,默认是row */ /*flex-wrap:nowrap; //子元素超出父级后是否换行,默认不换行,设置的宽度会失效 */ /*flex-flow:row nowrap //上面两个属性的复合写法 */ /*子元素在父元素上的对其方式:flex-start前对齐||flex-end后对齐||center居中对齐||space-between和边缘无间距对齐||space-around和边缘有间距对齐*/ justify-content: space-between; } .div-box3>div{ width: 23%; } .div-box3>div:nth-child(n+2){ margin-left: 2%; }
居中方式四:宽度属性计算(不提倡,兼容性不好)
/*居中方式四:宽度属性计算(不提倡,兼容性不好)*/ .div-box4{ font-size: 0; } .div-box4>div{ display: inline-block; font-size: 16px; width: calc(23.5% - 32px); /*数学符号之间一定要有空格*/ } .div-box4>div:nth-child(n+2){ margin-left: 2%; }
以上四种方式实现的效果都是这样的:
最后,只有掌握最基础最底层的技术,才能在开发过程中更高效地完成任务。勤劳能致富,后面我要更努力去思考更有用的知识。:)
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/52045.html
摘要:怎样让多个元素贴边平分为什么会有这个疑问呢首先说明一下,接触前端有一年的时间了,自认为对静态布局不在话下,果然,自负的人最容易被打脸呐,刚换了一份工作,公司对前端要求比较严格。 怎样让多个元素贴边平分? 为什么会有这个疑问呢?首先说明一下,接触前端有一年的时间了,自认为对静态布局不在话下,果然,自负的人最容易被打脸呐,刚换了一份工作,公司对前端要求比较严格。 ...
摘要:目录布局父项常见属性布局父项常见属性一一属性属性演示演示二二属性属性演示演示 目录 flex布局父项常见属性 一、flex-direction 1.属性 2.演示 flex-direction: row; flex-direction: row-reverse; f...
摘要:基于这样的布局方式,你就可以把什么定高不定高定宽不定宽多行单行的水平垂直居中都搞定了。且不支持这就是所谓的布局大法。 看了这篇文章,你可以了解到以下布局方法: table-cell 定高水平垂直居中 不定高水平垂直居中 单行定高水平垂直居中 单行不定高水平垂直居中 多行定高水平垂直居中 多行不定高水平垂直居中 多列等高布局 左边定宽右边自适应布局 左边右边定宽中间自适应三列布局 最...
阅读 2511·2023-04-25 22:09
阅读 1024·2021-11-17 17:01
阅读 1560·2021-09-04 16:45
阅读 2621·2021-08-03 14:02
阅读 817·2019-08-29 17:11
阅读 3257·2019-08-29 12:23
阅读 1091·2019-08-29 11:10
阅读 3281·2019-08-26 13:48