激进的margin属性

margin与元素尺寸以及相关布局

  • 元素尺寸

border box尺寸,对应jQuery中的$().outerWidth()和$().outerHeight()方法,在原生DOM API中写作offsetWidth和offsetHeight,所以有时候也称为“元素偏移尺寸”

  • 元素内部尺寸

padding box尺寸,对应jQuery中的$().innerWidth()和$().innerHeight()方法,在原生DOM API中写作clientWidth和clientHeight,所以有时候也称为“元素可视尺寸”

  • 元素外部尺寸

margin box尺寸,不仅包括padding和border,还包括margin,对应jQuery中的$().outerWidth(true)和$().outerHeight(true)方法,没有对应的原生DOM API

margin与元素的内部尺寸

当元素是“充分利用可用空间”状态的时候,margin可以改变元素的可视尺寸。

<div class="father"><div class="son"></div>
</div>.father { width: 300px; }
.son { margin: 0 -20px; }

  这里.son元素的宽度是340px,此时的宽度表现就是“充分利用可用空间”

CSS世界默认的流方向是水平方向,因此,对于普通元素,margin只能改变元素水平方向尺寸。但是,对于具有拉伸特性的绝对定位元素,则水平或垂直方向都可以

由于margin具有这种流体特性下的改变尺寸特性,因此,margin可以很方便地实现很多流体布局效果。例如:一侧定宽的两栏自适应布局效果,假设我们定宽的部分是128像素宽的图片,自适应的部分是文字。

(1)如果图片左侧定位:

.box { overflow: hidden; }
.box > img { float: left; }
.box >p { margin-left: 140px; }<div class="box"><img src="1.jpg"><p>文字内容……</p>
</div>

此时,文字内容会根据.box盒子的宽度变化而自动排列,形成自适应布局效果

(2)图片右侧定位

.box { overflow: hidden; }
.box > img { float: right; }
.box >p { margin-right: 140px; }

HTML 与上面的左侧定位效果一模一样,最终实现的也是一个效果良好的自适应布局。有一点瑕疵的地方在于:元素在DOM文档流中的前后顺序和视觉表现上的前后顺序不一致。如果想要实现顺序完美一致的自适应效果——

(3)图片右侧定位,同时顺序一致

.box { overflow: hidden; }
.full { float: left; width: 100%; }
.box > img { float: left; margin-left: -128px; }
.full>p { margin-right: 140px; }<div class="box"><div class="full"><p>文字内容……</p></div><img src="1.jpg">
</div>

内联元素垂直方向的margin是没有任何影响的,既不会影响外部尺寸,也不会影响内部尺寸。对于水平方向,由于内联元素宽度表现为“包裹性”,也不会影响内部尺寸

margin百分比值

和padding属性一样,margin的百分比值无论是水平方向还是垂直方向都是相对于宽度计算的

转载于:https://www.cnblogs.com/beginner2014/p/9462821.html

《CSS世界》读书笔记(十一)相关推荐

  1. 《Android源码设计模式解析与实战》读书笔记(十三)

    第十三章.备忘录模式 备忘录模式是一种行为模式,该模式用于保存对象当前的状态,并且在之后可以再次恢复到此状态,有点像是我们平常说的"后悔药". 1.定义 在不破坏封闭的前提下,捕获 ...

  2. 《Android源码设计模式解析与实战》读书笔记(十七)

    第十七章.中介者模式 中介者模式也称为调解者模式或调停者模式,是一种行为型模式. 1.定义 中介者模式包装了一系列对象相互作用的方式,使得这些对象不必相互明显作用.从而使它们可以松散耦合.当某些对象之 ...

  3. 《Android源码设计模式解析与实战》读书笔记(十二)

    第十二章.观察者模式 观察者模式是一个使用率非常高的模式,它最常用在GUI系统.订阅–发布系统.因为这个模式的一个重要作用就是解耦,将被观察者和观察者解耦,使得它们之间的依赖性更小,甚至做到毫无依赖. ...

  4. 《Android源码设计模式解析与实战》读书笔记(十四)

    第十四章.迭代器模式 迭代器模式,又叫做游标模式,是行为型设计模式之一.我们知道对容器对象的访问必然会涉及遍历算法,我们可以将遍历的方法封装在容器中,或者不提供遍历方法,让使用容器的人自己去实现去吧. ...

  5. 《Android源码设计模式解析与实战》读书笔记(十)

    第十章.解释器模式 解释器模式是一种用的比较少的行为型模式,其提供了一种解释语言的语法或表达式的方式.但是它的使用场景确实很广泛,只是因为我们自己很少回去构造一个语言的文法,所以使用较少. 1.定义 ...

  6. 《Android源码设计模式解析与实战》读书笔记(二十四)

    第二十四章.桥接模式 桥接模式也称为桥梁模式,是结构型设计模式之一.桥接模式中体现了"单一职责原则"."开闭原则"."里氏替换原则".&qu ...

  7. 《Android源码设计模式解析与实战》读书笔记(二十一)

    第二十一章.装饰模式 装饰模式也称为包装模式,是结构型设计模式之一.装饰模式是一种用于替代继承技术的一种方案. 1.定义 动态的给一个对象添加一些额外的职责.就增加功能来说,装饰模式相比生成子类更为灵 ...

  8. 《Android源码设计模式解析与实战》读书笔记(十一)

    第十一章.命令模式 命令模式是行为型模式之一.总体来说并不难理解,只是比较繁琐,他会将简单的调用关系解耦成多个部分,增加类的复杂度,但是即便如此,命令模式的结构依然清晰. 1.定义 将一个请求封装成一 ...

  9. 《Android源码设计模式解析与实战》读书笔记(十九)

    第十九章.组合模式 组合模式也称为部分-整体模式,结构型设计模式之一. 1.定义 将对象组合成树形结构以表示"部分-整体"的层次结构,使得用户对单个对象和组合对象的使用具有一致性. ...

  10. 《Android源码设计模式解析与实战》读书笔记(十六)

    第十六章.访问者模式 访问者模式是一种行为型模式,它是23种设计模式中最复杂的一个,虽然使用频率不高,但是并不代表可以忽略,在合适的地方,它会带来意想不到的灵活性.访问者模式,顾名思义使用了这个模式后 ...

最新文章

  1. 常见浏览器User-Agent大全
  2. NFS、SSH、SAMBA
  3. 深入理解JVM(一)编译openJDK
  4. python—web页面操作之3种等待方式
  5. IOS -- UICollectionView里面的cell点击,点击一个cell改变其他cell的状态
  6. 手动实现SPring中的AOP(1)
  7. 动态代理Java实现
  8. 面向项目(十一)—— 库的使用
  9. Ubuntu20.04安装OpenCV3.4.15
  10. DDR的VTT有源端接和无源端接(slua886a笔记)
  11. 阿里天池比赛——地表建筑物识别
  12. 支付宝支付-当面付和App支付
  13. 轻量级智能穿戴开发基础组件:input
  14. 二级c语言百度云,全国计算机二级C语言历年真题完整版.pdf
  15. python苹果支付(服务端)自动订阅版
  16. echarts找到china地图( npm i --save echarts/map/js/China)
  17. 传奇服务器账号禁止登陆,传奇私服网关禁止登陆
  18. Linux系统的学习小结
  19. ccs船级社认证费用多少_​船级社认证费用知多少?-常见问题FAQ-「上海思绪」-CCS中国船级社_BV法国_DNVGL挪威船级社_LR英国劳氏船级社_ABS美国船级社...
  20. Win11 部分屏幕无法点击的bug

热门文章

  1. 造成ORA-12560: TNS: 协议适配器错误的问题的原因有三个:
  2. UVA 10570 Meeting with Aliens
  3. s3c2410下利用TL16C554扩展4个全功能串口
  4. PHP中不被注意但是比较重要的函数用法集合
  5. GitHub的MySQL高可用性实践
  6. 小知识一、让Swift继续用OC#warning效果
  7. 我一不小心把ubuntu里的ps这样的命令删掉了,应该怎么重装呢
  8. Yii2框架源码分析之如何实现注册和登录
  9. linux网络命令记录
  10. lua 函数调用1 -- 闭包详解和C调用