首页 / CSS / 深入了解CSS外边距margin元素
深入了解CSS外边距margin元素
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了深入了解CSS外边距margin元素,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5188字,纯文字阅读大概需要8分钟。
内容图文
![深入了解CSS外边距margin元素](/upload/InfoBanner/zyjiaocheng/415/42e03f646225476dbe322b40a0f3419a.jpg)
前面的话
??margin是盒模型几个属性中一个非常特殊的属性。简单举几个例子:只有margin不显示当前元素背景,只有margin可以设置为负值,margin和宽高支持auto,以及margin具有非常奇怪的重叠特性。之前的博文中已经分别详细地介绍了margin的基础知识和负margin的详细用法。本文将详细介绍外边距margin的几个重点部分,包括重叠、auto和无效情况
重叠
【前提】
??margin重叠又叫margin合并,发生这种情况有两个前提
??1、只发生在block元素上(不包括float、absolute、inline-block元素)
??2、只发生在垂直方向上(不考虑writing-mode)
【分类】
??margin重叠共包括以下3种情况
1、相邻的兄弟元素
<style> p{ line-height: 2em; margin:1em 0; background-color: lightblue; display:inline-block; width: 100%; } </style> <p>兄弟一</p> <p>兄弟二</p>
2、父级元素和第一个或最后一个子元素,父子级的margin重叠又叫margin传递
<style> .box{ background-color: pink; height:30px; } .inner{ margin-top: 1em; background-color: lightblue; } </style> <p class="box"> <p class="inner">子级</p> </p>
条件
??相对比相邻兄弟元素margin重叠来说,父子级margin重叠需要满足以下几个条件(以margin-top重叠为例):
??a、父元素不是BFC元素
??b、父元素没有padding-top值
??c、父元素没有border-top值
??d、父元素和第一个子元素之间没有inline元素分隔
??如果是父子级的margin-bottom重叠,第d条改为父元素和最后一个子元素之间没有inline元素分隔,以及还需要满足父元素没有height、min-height、max-height限制
3、空的block元素
<style> .box{ background-color: lightgreen; overflow: hidden; } .void{ margin: 1em 0; } </style> </head> <body> <p class="box"> <p class="void"></p> </p> 一行文字
??从下面结果中,可以看出空block元素应该撑开父级margin-top+margin-bottom共2em的高度,但由于margin重叠,只有1em
??同样地,空block元素发生margin重叠也需要满足一些条件
??a、元素没有border值
??b、元素没有padding值
??c、里面没有inline元素
??d、没有height或min-height
【规则】
??两个正垂直外边距,浏览器取大值;如果垂直外边距都设置为负值,浏览器会选取两个外边距的绝对值的最大值;如果一个正外边距与一个负外边距合并,会从正外边距减去这个负外边距的绝对值
??简单点说,就是正正取大值、正负值相加、负负最负值
【用途】
??在网页布局中,因为margin重叠的原因,我们常常把margin作为一个“问题样式”而尽量少地使用它。但实际上,它是在很大的作用的
??HTML文档创建的初衷只是用来展示信息的。HTML文档只使用默认样式的前提下,如果上下margin不发生重叠,则会出现以下几个问题:1、连续段落或列表之类,如果没有margin重叠,首尾项间距会和其他兄弟元素呈现1:2的关系,排版不自然;2、web中任何地方嵌套或直接放入任何裸p,都会影响原生的布局,与web设计原则相违背;3、遗落的空的任意多个p标签,会影响原来的阅读排版
??所以,我们要善用重叠,可以在列表项中同时使用margin-top和margin-bottom。这样,使页面结构更具有健壮性,最后一个元素移除或位置调换,都不会破坏原生的布局
【新属性】
-webkit-margin-collapse
-webkit-margin-collapse: <collapse>(默认重叠) | <discard>(取消) | <separate>(分隔)
??该属性用于设置margin是否重叠,作用于发生margin重叠的两个元素之一。如果,两个都使用该属性,一个设置为discard,一个设置为separate,则最终效果为重叠collase
auto
??只有width/height和margin可以设置auto。关于auto的详细信息,已经在CSS视觉格式化中详细介绍过。下面仅介绍关于margin:auto的部分
【为什么margin:auto无法实现垂直居中】
??水平方向可以居中是因为块级元素的宽度默认是撑满父级元素的,如果给宽度设置一个固定值,而左右margin设置为auto,则可以平分剩余空间
??垂直方向不可以居中是因为块级元素的高度默认是内容高度,与父级元素的高度并没有直接的关系,而上下margin设置为auto,则被重置为0
【为什么图片使用margin:auto不能水平居中】
??图片无法水平居中,类似于块级元素无法垂直居中。因为图片的宽度width默认是自身宽度,与父元素的宽度没有直接关系。左右margin设置为auto,会被重置为0
??所以,图片要水平居中,需要设置为display:block元素
【实现垂直居中】
??使用margin:auto实现垂直居中,有以下两种方法
??1、使用writing-mode:vertical-lr;
??writing-mode代表页面流方向,默认是水平方向。改为垂直方向后,可实现垂直居中,但水平不居中了
??2、将元素变为绝对定位元素(IE7-浏览器不支持)
??将元素变为绝对定位元素后,设置top:0;bottom:0;,使绝对定位元素与定位父级的高度有了直接的联系。再设置margin:0 auto;,使margin-top和margin-bottom平分剩余空间,达到垂直居中的效果
无效情形
??1、行内元素垂直margin无效
??因为行内元素垂直布局主要是通过行高line-height和垂直对齐vertical-align来影响的,垂直margin并不会影响它们,所以不会影响垂直布局。而在显示方式,margin区域不会显示元素背景,所以也不会影响自身元素的显示,所以行内元素垂直margin无效
??[注意]不包括inline-block或设置writing-mode为vertical-lr的情况
??2、某些表格类元素margin无效
??<thead>``<tbody>``<tfoot>``<tr>``<col>``<colgroup>``<td>``<th>
不可设置margin。对于display属性来说,display为table相关类型(不包括table-caption、table、inline-table),margin声明无效
??3、绝对定位元素非定位方向的margin值看似无效
??绝对定位的margin值是一直有效的,只是因为绝对定位元素是脱离文档流的,与其他元素节点没有什么关系,所以看不出效果
??4、BFC造成的margin看似无效
??左侧元素使用浮动,右侧元素使用overflow-hidden实现两栏自适应的布局时,右侧元素的margin-left值只有足够大,才能看到效果。这是因为margin-left是相对于父元素左侧,而不是图片右侧
??5、内联特性导致的margin无效
??一个p里面包着一张图片,当图片的margin-top小到一定值时,图片就不再接着向上移动了。这是因为图片是内联元素,它受制于内联元素vertical-align对齐特性的影响。默认基线对齐。以页面假想的大写X字符为例,X是不会因为图片margin-top足够小而跑到父元素外面的,所以图片移动到一定位置就不再接着向上移动了
以上就是深入了解CSS外边距margin元素的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的深入了解CSS外边距margin元素全部内容,希望文章能够帮你解决深入了解CSS外边距margin元素所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。