一、margin可以为负值
在盒模型中,内容区的width/height、padding、border都不能为负值,但是margin例外,它可以为负值。
关于margin负值的使用技巧,了解不多,日后有机会再补充,此处先贴一个经典应用,margin-left负值结合浮动实现不改变DOM结构的流体布局。
此demo与CSS float浅析篇中的是同一个。
XML/HTML Code复制内容到剪贴板- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>不改变DOM结构的流体布局</title>
- <style>
- .container {
- width:600px;
- margin-left: auto;
- margin-right: auto;
- background-color: orange;
- font-size: 16px;
- line-height: 1.5;
- }
- .box1 {
- width:100%;
- float:left;
- }
- .box2 {
- margin-right: 220px;
- padding-left: 20px;
- }
- img {
- width:200px;
- float:left;
- margin-left:-200px;
- }
- .clearfix:after {
- content: "";
- display: table;
- clear: both;
- }
- .clearfix {
- *zoom: 1;
- }
- </style>
- </head>
- <body>
- <div class="container clearfix">
- <div class="box1">
- <div class="box2">
- <h3>不改变DOM位置的流体布局</h3>
- <p>假如有一段文本和一幅图像,在DOM节点中,文本在前,图像在后,怎么能把图像定位到右边呢?</p>
- <p>通常的做法是,调换DOM节点中图像与文本的位置,让图像在前,文本在后,然后将图像浮动到右边即可。</p>
- <p>但这样改变DOM节点顺序始终不妥,还有什么更好的方法呢?</p>
- <p>下面就介绍一种新的思路来完成布局。</p>
- <ul>
- <li>将文本用div包起来,定义为box1;现在的结构是一个box1和一个img。</li>
- <li>将box1宽度设为100%,左浮动;将img设置一个宽度,也左浮动,然后margin-left设为负的宽度值;此时图像就定位到文本的右边啦。</li>
- <li>但是有一个问题,图像盖住了文本内容,这可怎么办?</li>
- <li>重点来了,在box1中增加一个box2,box2把文本全部包起来,然后margin-right设为图像的宽度(+额外的间距),这样就解决问题啦!</li>
- </ul>
- </div><!--关闭box2-->
- </div><!--关闭box1-->
- <img src="http://imgsrc.baidu.com/forum/w%3D580/sign=0c101fe665380cd7e61ea2e59145ad14/f9a3492762d0f7032de1758a08fa513d2797c542.jpg" alt="a picture" style="width:200px;height:300px" />
- </div><!--关闭container-->
- </body>
- </html>
二、margin的百分比数值
当margin属性的值为百分数时,其总是以父元素的width为基数进行计算。
请看下面这个demo,当初折磨了我N久的。。。只怪我知道得太晚了,说多了都是泪啊。。。
XML/HTML Code复制内容到剪贴板- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>margin的百分数值</title>
- <style>
- .container {
- width: 500px;
- height: 300px;
- margin: 50px auto;
- background-color: orange;
- border: 1px solid black;
- }
- .box {
- width: 250px;
- height: 150px;
- margin-left: auto;
- margin-right: auto;
- background-color: cyan;
- }
- .box1 {
- margin-top: 75px;
- margin-bottom: 75px;
- padding: 5px;
- }
- .box2 {
- margin-top: 25%;
- margin-bottom: 25%;
- padding: 5px;
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="box box1">
- <p>父元素的高度为300px,子元素的高度为150px,只要margin-top和margin-bottom都为75px,这个盒子就能垂直居中。</p>
- <p>OK,居中啦!!!</p>
- </div>
- </div>
- <div class="container">
- <div class="box box2">
- <p>既然子元素的高度是父元素高度的50%,那么只要margin-top和margin-bottom都为25%,应该也能垂直居中。</p>
- <p>额,这什么鬼?说好的居中呢?</p>
- </div>
- </div>
- </body>
- </html>
三、垂直方向上margin的合并
这个问题经常造成一些困惑,不过只需要记住一句话即可,垂直方向上的margin只要亲密接触就会合并,也只有亲密接触才会合并。
垂直方向上margin的合并,如果发生在相邻元素,其实是很好理解的;但是如果发生在父元素与子元素之间,就有些怪异了。
来看例子:
XML/HTML Code复制内容到剪贴板- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>垂直方向上的margin合并</title>
- <style>
- .container {
- width: 500px;
- height: 300px;
- margin: 50px auto;
- background-color: orange;
- }
- .box {
- width: 300px;
- height: 200px;
- margin-left: auto;
- margin-right: auto;
- background-color: cyan;
- margin-top: 25px;
- padding: 5px;
- }
- .border {
- border: 1px solid black;
- /*padding: 1px;*/
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="box">
- <p>父元素的margin-top为50px,子元素的margin-top为25px;</p>
- <p>咦,子元素的margin-top呢?为什么都顶到父元素上边界了?</p>
- <p>额,因为父元素与子元素的margin-top亲密接触了呀,所以它们合并在一起了啊。</p>
- </div>
- </div>
- <div class="container border">
- <div class="box">
- <p>可是我就是想让子元素距离父元素的上边界25px啊,我不想让它们合并呀。</p>
- <p>很简单,给父元素加个边框,它们就无法亲密接触了,就不会合并了啊。</p>
- <p>或者给父元素设置padding也是可以的喔。</p>
- </div>
- </div>
- </body>
- </html>
消除垂直方向上margin合并的方法:给父元素加border或者加padding,打破父元素与子元素margin之间的亲密接触即可。
margin合并的规则:
XML/HTML Code复制内容到剪贴板- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>margin合并规则</title>
- <style>
- .container {
- width: 300px;
- height: 500px;
- margin: 50px;
- background-color: orange;
- float: left;
- border: 1px solid black;
- }
- .box1,.box2,.box3,
- .box4,.box5,.box6 {
- width: 200px;
- height: 150px;
- margin: 30px auto;
- background-color: cyan;
- text-align: center;
- line-height: 150px;
- }
- .box1 {
- margin-bottom: 30px;
- }
- .box2 {
- margin-top: 20px;
- }
- .box3 {
- margin-bottom: 30px;
- }
- .box4 {
- margin-top: -30px;
- }
- .box5 {
- margin-bottom: -30px;
- }
- .box6 {
- margin-top: -50px;
- background-color: green;
- }
- p {
- width: 220px;
- margin:10px auto;
- font-size: 16px;
- line-height: 1.5;
- }
- </style>
- </head>
- <body>
- <div class="container">
- <div class="box1">box1</div>
- <div class="box2">box2</div>
- <p>box1的margin-bottom为30px,box2的margin-top为20px,两个margin都是正数,取绝对值大的。</p>
- </div>
- <div class="container">
- <div class="box3">box3</div>
- <div class="box4">box4</div>
- <p>box3的margin-bottom为30px,box4的margin-top为-30px,两个margin一正一负,相加。</p>
- </div>
- <div class="container">
- <div class="box5">box5</div>
- <div class="box6">box6</div>
- <p>box5的margin-bottom为-30px,box6的margin-top为-50px,两个margin都是负数,取绝对值大的。</p>
- </div>
- </body>
- </html>
1. 两个margin都是正数,取绝对值大的;
2. 一个margin是正数,另一个margin是负数,相加;
3. 两个margin都是负数,取绝对值大的。
以上这篇CSS margin全面了解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
原文地址:http://www.cnblogs.com/cc156676/archive/2016/07/21/5690270.html
CSS,margin
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]