• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS 之margin知识点(必看)

CSS 之margin知识点(必看)

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,margin等相关知识,佚名 希望在学习及工作中可以帮助到您

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

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

结果如下

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

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

 

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

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

比如 有两个容器

 

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

4. margin 的重叠 为什么重叠

A) margin 重叠的两个特性

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

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

B) 发生的情况

1> 相邻的兄弟元素

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

3> 空的 block。 

例子一 相邻的兄弟元素

   

  这里就是两个兄弟元素 。

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

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

 

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

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

父子 margin重叠的 条件

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

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

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

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

  

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

4 margin重叠的计算规则。

A) 正正取大值

B) 正负值相加

C) 负负取最负。

5. margin 重叠的意义

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

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

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

实际应用

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

.list{

margin-top : 15px;

margin-bottom: 15px;

}

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

以上这篇CSS 之margin知识点(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持微课江湖。

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06举例详解CSS中的text-shadow文字阴影效果使用
  • 2017-08-06使用CSS实现小三角形效果【附实例】
  • 2017-08-06CSS3中的clip-path使用攻略
  • 2017-08-06用SMACSS规范来编写CSS
  • 2017-08-06CSS伪类和伪元素的区别详解
  • 2017-08-06CSS3动画:5种预载动画效果实例
  • 2017-08-06使用CSS3在触屏上为按钮实现激活效果
  • 2017-08-06DIV遮罩层如何实现
  • 2017-08-06关于CSS中 星号*的使用介绍
  • 2017-08-06ie6下a标签的onclick事件不执行问题解决方案

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 谈谈对css属性box-sizing的了解
    • IE7 float:left左浮动失效的解决方法
    • CSS 空格引起网页布局间距问题
    • min-width最小宽度的作用介绍
    • 纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
    • CSS3打造磨砂玻璃背景效果
    • 带有css3动画效果的兼容多浏览器简单导航条示例
    • 纯css3实现鼠标经过图片显示描述的动画效果
    • hideFocus(虚线框处理小技巧)
    • 网站日志200 0 64状态码的分析(协议子状态)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有