CSS属性之margin
2018-06-24 00:57:50来源:未知 阅读 ()
0.对自身可视宽度的影响
1>改变处于标准文档流中,未设置width值的block元素的可视宽度
在标准文档流中,对于没有设置宽度的block元素,当其具有内容或者设置高度后,其自身宽度为父元素宽度的100%,这个时候给block元素设置水平方向的margin值,就会改变元素的可视宽度。但是不能改变高度,因为block元素的高度是固定或者等于其内容的高度,并不会拉伸。
这个特点在bootstrap的布局里就有用到。
<div class="wrap"> 父元素padding: 0 10px; <div class="yellow">此block元素没有设置margin值</div> <div class="red">此block元素设置margin-left:-10px;margin-right:-10px; 拉伸了元素宽度</div> </div>
* {margin:0; padding:0;} .wrap { width: 400px; height: 400px; margin: 50px auto; padding: 0 10px; border: 1px solid #ccc; } .red { height: 100px; background-color: red; margin: 0 -10px; } .yellow { height: 100px; background-color: yellow; }
2>改变未设置宽度,但是设置了定位(成对设置的定位,如:top/bottom,left/right)的绝对定位元素的可视宽高
当绝对定位元素没有设置width,但设置了top/bottom,left/right值时,元素会被拉伸。比如设置left:0; right:0; 元素的宽度就是第一个相对定位的父元素的宽度的100%了,这时也能通过margin来改变元素的可视宽度。同样,对于绝对定位元素,我们也能改变它的可视高度。
<div class="wrap"> 父元素position: relative; <div class="yellow">绝对定位,并且设置top:0; bottom:0; 垂直拉伸元素,通过设置margin来改变可视高度</div> </div>
* {margin:0; padding:0;} .wrap { position: relative; width: 400px; height: 400px; margin: 50px auto; border: 1px solid #ccc; } .yellow { position: absolute; top: 0; bottom: 0; width: 100px; margin: 50px 0; background-color: yellow; }
1.百分比值的margin
跟padding一样,对于正常处于标准文档流的元素而言,当元素的margin值为百分比值时,其实际值等于父元素的宽度*百分比;
当元素设置绝对定位后,其实际值等于第一个相对于它定位的父元素的宽度*百分比
<div class="wrap"> 父元素宽度400px; <div class="yellow">margin-top:10%; 实际的margin-top=400px*10%=40px</div> </div>
* {margin:0; padding:0;} .wrap { width: 400px; height: 400px; margin: 50px auto; border: 1px solid #ccc; } .yellow { width: 200px; height: 200px; margin-top: 10%; background-color: yellow; }
2.margin重叠
margin重叠通常发生在兄弟元素之间以及父子元素之间,如果大家平时没有注意的话,margin重叠可能常常会给我们带来一些小麻烦,这里就把发生margin重叠的情况总结一下。
1>兄弟元素之间
当两个元素发生margin重叠时,其实际值的情况:
- 当两个margin值都为正时,实际值=两个中较大的值
- 当两个margin值是一正一负时,实际值=两个值相加
- 当两个margin值都为负时,实际值=两个中绝对值大的
那什么时候会发生margin重叠呢?
对于两个相邻的兄弟元素而言,只要是处于标准文档流中的block元素,垂直方向都会发生margin重叠。
2>父元素与第一个/最后一个子元素之间
- 设置border-top/bottom
- 设置padding-top/bottom
- 设置overflow:hidden/auto等属性,实现BFC
3.margin的auto值
给一个定宽的block元素设置margin: 0 auto;使元素水平居中,这应该是很多人经常使用的,不过对于auto值的具体作用,可能很少有人知道。
简单点说,对于未设置固定width或height值的元素,如果能自动拉伸,那么当设置了固定值后,auto就可以用来分配剩余空间大小。
感觉有点拗口,举个例子,有一个定宽的block元素,我们想让他在右边显示,最常用的就是使用float属性,不过用margin-left: auto;一样可以实现:
<div class="wrap"> <div class="red">margin-left: auto;</div> </div>
* {margin:0; padding:0;} .wrap { position: relative; width: 400px; height: 400px; margin: 50px auto; border: 1px solid #ccc; } .red { width: 100px; height: 100px; background-color: red; margin-left: auto; }
设置margin值为auto的有效场景包括:
- 普通定宽block元素,水平方向设置有效;
- 绝对定位元素,在设置了成对left/right,top/bottom或者都设置的情况下,定宽或定高都有效;
- 在父元素为display: flex;的情况下,子元素margin值为auto都有效
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:网页基础知识
下一篇:flex布局——回顾
- DIV居中的经典方法 2020-06-13
- CSS中的float和margin的混合使用 2020-06-11
- Html/css 列表项 区分列表首尾 2020-06-11
- css与javascript重难点,学前端,基础不好一切白费! 2020-06-11
- ie8下透明度处理 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash