成都创新互联网站制作重庆分公司

CSS的margin实例用法-创新互联

本篇内容主要讲解“CSS的margin实例用法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS的margin实例用法”吧!

10年积累的做网站、网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先建设网站后付款的网站建设流程,更有历城免费网站建设让你可以放心的选择与我们合作。

1.margin的百分比值普通元素的百分比maigin相对于容器元素的宽度(width) 进行计算的。

这里我们在图片外面设置一个宽高分别为800 * 600的容器。设置img{ margin: 10%; }

结果如下

CSS的margin实例用法  
结果margin值都是 800 * 10% = 80px; 所以这里都是相对于容器的宽度计算的 容器的宽度计算 容器的宽度计算。说三遍

2.绝对定位的百分比maigin值

CSS的margin实例用法CSS的margin实例用法 CSS的margin实例用法

相对于第一个定位的祖先元素的 width值计算的。就是 parent 的 width = 1000px. 所以 margin = 100px;

3.可以使用margin 实现 2 : 1 的自适应

比如 有两个容器

CSS的margin实例用法 CSS的margin实例用法

这里 box的高度没有指定。 由于设置 margin 50% 。他的高度就是父容器的一半  所以高宽比就是 1 : 2;

CSS的margin实例用法

4. margin 的重叠 为什么重叠

A) margin 重叠的两个特性

只会发生在block的水平元素上。 (不包括 float 和 absolute元素)

不考虑 wirte-mode(就是书写格式)  只发生在 垂直方向(margin-top margin-bottom)

B) 发生的情况

1> 相邻的兄弟元素

2> 父级的第一个 和 最后一个子元素

3> 空的 block。

例子一 相邻的兄弟元素

CSS的margin实例用法    CSS的margin实例用法

  这里就是两个兄弟元素 。

CSS的margin实例用法 这里的 两个p 之间只有一个em 没有两个em。 因为第一个margin-bottom 和 第二个的 margin-top 发生了重叠。

例子二 父元素和最后一个子元素 重叠

CSS的margin实例用法 CSS的margin实例用法

按照常规理论 son 和 父元素的 father 之间会 留出 80px的 margin-top值。但是实际上没有。son的背景元素没有变化 没有留出80px;

这里只是 给 父元素设置了 80px;

CSS的margin实例用法

父子 margin重叠的 条件

CSS的margin实例用法CSS的margin实例用法

那么怎么干掉margin-top 重叠呢?

只要不让它满足那些条件就可以了。

父元素添加 overflow: hidden;  border-top  padding-top (在他们之间加个空格);

例子三 空block元素的 margin 重叠。


CSS的margin实例用法   CSS的margin实例用法

注意里面没有任何内容的空元素 。空元素发生margin重叠的条件


CSS的margin实例用法

4 margin重叠的计算规则。

A) 正正取大值

B) 正负值相加

C) 负负取最负。

5. margin 重叠的意义

A)  连续段落或列表之类 如果没有margin重叠 收尾出现 1 : 2 就会显得不协调

B) web 中任何地方嵌套或直接放div 都不会影响原来的布局

C) 遗落的空的任意 多个p元素 不要影响原来阅读的排版

实际应用

制作列表 的时候控制每个列表的距离里面的

CSS的margin实例用法

.list{

margin-top : 15px;

margin-bottom: 15px;

}

更具有健壮性 即使最后一个 移除了 亦不会影响布局

到此,相信大家对“CSS的margin实例用法”有了更深的了解,不妨来实际操作一番吧!这里是创新互联建站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


网页标题:CSS的margin实例用法-创新互联
文章路径:http://cxhlcq.com/article/ecgji.html

其他资讯

在线咨询

微信咨询

电话咨询

028-86922220(工作日)

18980820575(7×24)

提交需求

返回顶部