负margin的原理以及应用
负margin在布局中往往起到意想不到的效果,比如在多栏等高布局中就是用该技巧。
虽说网络上关于负margin的实践有很多,但对margin负值为什么会出现这样的效果却没有多少讲解,本篇的目的就是阐述负margin
产生或者作用的原因。
margin负值之所以可以修改元素在文档流中的位置,也可以改变元素的宽度,主要因为一个公式:
BoxWidth =ChildMarginLeft + ChildBorderLeftWidth + ChildPaddingLeft + ChildWidth + ChildPaddingLeft + ChildBorderRightWidth + ChildMarginRightWidth;
上述公式很容易理解,熟悉box模型的都应该明白。
margin负值之所以起到了意想不到的作用,主要是因为该公式的各种计算导致了一些属性值的改变所引起。
口说无凭,先举几个例子:
ex1.
1 .m-20{margin-bottom: -20px;}
2 .m-200{margin-bottom: -200px;}
3 .l{float:left;}
4 .h200{height:200px;}
5 .m-20{margin-bottom:-20px;}
6 .m-200{margin-bottom:-200px;}
7
8
9 <div class="l pct40 bg-gray mr20">
10 <div class="h200 m-20 bg-teal pct40"></div>
11 </div>
12 <div class="l pct40 bg-gray">
13 <div class="h200 m-200 bg-teal pct40"></div>
14 </div>


第一个父div的子元素margin-bottom设为-20px;根据上述公式,由于子元素的height是定值,为200px,padding为0,带入可得ParentHeight=180px;正如图显示。
第二个父div的子元素margin-bottom设为-200px,同理可得ParentHeight= 0px,图上并没有显示。
ex2.
.eqh{padding-bottom: 220px;margin-bottom: -200px;}
.ovh{overflow:hidden;}
.cl{clear:both;}
<div class="cl w500 mt20 l ovh">
<div class="l w200 bg-silver mr20 eqh">
<p>这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
</p>
</div>
<div class="l w200 bg-silver eqh">
<p>这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题这是一个测试题
这是一个测试题
这是一个测试题
这是一个测试题
</p>
</div>
</div>

这就是margin负值应用最多的场景,多栏等高布局,总共2个子div,第一个子div的padding-bottom撑开子div的高度--两行文字高度为38px,padding的高度为220px,所以第一个子元素高度为258px,在不考虑第二个子div存在的情况下,父div高度=258-200-0-0-0-0-0=58px;
再计算第二个div,同样的公式,只是带入的数值不同,此时第二个子div的高度为334px,在考虑margin-bottom为-200px的情况,计算出父div高度=334-200=134px;
此后将计算结果综合,父div高度取最大值,为134px,这就是最后的浏览器呈现给我们的视图。
有些人会发现当元素的width属性设置为auto,或者不设置width时,margin-left或者margin-right为负值可能改变元素的大小,这种说法不严谨。
老方法,还是根据上述万能公式,左右margin的值(不论正负),在其父元素宽度(即ParentWidth)给定的情况下,会根据margin值的改变,来响应改变元素的width值,有些类似所谓的控制变量法!
另,现比较另外一个属性,vertical-align:-2px 与margin-bottom:-2px的区别所在。
对于vertical-align,我们主要用来元素的居中显示,很少用具体的值。但是有些情况,vertical-align的负值会有出其不意的效果。
二话不说,先上个demo:
.m-200{margin-bottom: -200px;}
.v-200{vertical-align: -200px;}
<div class="l pct40 bg-gray mr20">
<div class="h200 v-200 bg-teal pct40"></div>
</div>
<div class="l pct40 bg-gray">
<div class="h200 m-200 bg-teal pct40"></div>
</div>

第一个div中,蓝色子元素采用了vertical-align:-200px,父元素高度和子元素相同;
第二个div中,蓝色子元素采用margin-bottom: -200px,父元素高度为0;
现在改变变量,将数值改为-20px,再看看:

可以明显看到,第一个div,子元素和父元素高度仍然相同,第二个div,父子元素不同,但仍满足上面的万能公式。
由此可以看出,通过vertical-align负值设置子元素,其呈现的位置和设置margin-bottom负值相同,不同点在于父元素框。
通过vertical-align负值设置的子元素的父元素的大小会增加,切不满足万能公式,而通过margin-bottom负值设置的子元素的父元素高度满足万能公式。
一言以蔽之,vertical-align会撑开父元素,而margin-bottom相应的根据上述公式计算会减小其高度。
负margin的原理以及应用的更多相关文章
- 负margin的原理及应用
在很多布局中我们经常能够见到类似于margin:-10px;的用法,我们对正值的用法早已熟悉的不能再熟悉了,可是这负值到底有何用呢?听我给你吹. 负margin——普通文档流 普通文档流元素(不浮动, ...
- [转]关于负margin在页面中布局的应用
本文转载自:http://www.cnblogs.com/jscode/archive/2012/08/28/2660078.html. 今天再写一个布局的时候用到一个margin-top是负值的情况 ...
- 负值之美:负margin在页面布局中的应用
本文转载自:http://www.topcss.org/?p=94,有修改. 负数给人总是一种消极.否定.拒绝之感,不过有时利用负margin可以达到奇妙的效果,今天就表一表负值在页面布局中的应用.这 ...
- 负margin在页面布局中的应用
关于负margin的原理建议大家看看这篇文章:http://www.cnblogs.com/2050/archive/2012/08/13/2636467.html#2457812 一. 左右列固定, ...
- 探究负边距(negative margin)原理
W3C规范在介绍margin时有这样一句话: Negative values for margin properties are allowed, but there may be implement ...
- 负margin使用权威指南
自CSS2早在1998年,推荐表的使用已经慢慢褪色成背景和历史书中.正因为如此,CSS布局从那时起一直编码优雅的代名词. 的所有CSS概念设计师所使用,奖项可能需要给负margin的使用是最至少谈论的 ...
- 负margin新解
第一篇 我知道你不知道的负Margin 分类: Html/CSS | 转载请注明: 出自 海玉的博客 本文地址: http://www.hicss.net/i-know-you-do-not-know ...
- 我知道你不知道的负Margin
现如今,负margin技术的应用可谓越来越广,任一个大型站点惊鸿一瞥之下都会有其身影所在.个人认为负margin技术是学习css路上必不可缺少的课题之一,许多高级应用及疑难杂症修复都可以使用负marg ...
- 负margin应用案例几则(转载+总结)
(一)自适应布局——左栏改右栏 这里先写个一列固定列宽,另一列自适应的两列布局,效果图: 侧栏移至右边,效果图: 其HTML <div class="wrap"> &l ...
随机推荐
- jQuery整理
近几日总是在用js写一些东西,jq用的反而少了,最近在工作中总是会用到不常用的jQuery方法,之前觉得可能用到的情况比较少,便没在意这些方法,结果吃了亏,现在准备重新总结一些jQuery中的一些常用 ...
- fasicon.js (无二维码版,如需要js创建二维码版本可联系我:770959294@qq.com)
/*** Created by 张云山 on 2016/12/9.*/(function(wins,doct){wins.fasicon = function(){this.name = " ...
- Eclipse更新SDK速度慢,解决办法
在SDK Manager -> tools -> options中: HTTP Proxy Server: mirrors.neusoft.edu.cn HTTP Proxy Port: ...
- 升级为iOS9后,默认请求类型为https,如何使用http进行请求会报错(引用他人的)
升级为iOS9后,默认请求类型为https,如何使用http进行请求会报错 The resource could not be loaded because the App Transport Sec ...
- 分区里的inode号是0号和1号的block
分区里的inode号是0号和1号的block 我相信大家在使用Linux的时候都遇到过误删文件系统数据的情况,不管是自己误删还是帮人家恢复误删 现在用的比较多的恢复工具大概是ext3grep .ext ...
- HDFS NameNode 设计实现解析
接前文 分布式存储-HDFS 架构解析,我们总体分析了 HDFS 架构的主要构成组件包括:NameNode.DataNode 和 Client.本文首先进一步解析 HDFS NameNode 的设计和 ...
- 业务安全通用解决方案——WAF数据风控
业务安全通用解决方案——WAF数据风控 作者:南浔@阿里云安全 “你们安全不要阻碍业务发展”.“这个安全策略降低用户体验,影响转化率”——这是甲方企业安全部门经常听到合作团队抱怨.但安全从业者加入公司 ...
- 优秀网站看前端 —— 小米Note介绍页面
刚开始经营博客的时候,我写过不少“扒皮”系列的文章,主要介绍一些知名站点上有趣的交互效果,然后试着实现它们.后来开始把注意力挪到一些新颖的前端技术上,“扒皮”系列便因此封笔多时.今天打算重开“扒皮”的 ...
- c#语言-高阶函数
介绍 如果说函数是程序中的基本模块,代码段,那高阶函数就是函数的高阶(级)版本,其基本定义如下: 函数自身接受一个或多个函数作为输入. 函数自身能输出一个函数,即函数生产函数. 满足其中一个条件就可以 ...
- 我为什么很烦在DB服务器上安装杀毒软件
常见的数据库连接问题无外乎是在数据库服务器本地可以连接SQL Server,但通过其他服务器就不可以连接.但这次我却碰到了相反的情况,在服务器本地无法通过IP/实例名连接,但从其他服务器却可以.而且每 ...