margin与padding的区别是什么?

目录

1.背景介绍

2.知识剖析

3.常见问题

4.解决方案

5.编码实战

6.扩展思考

7.参考文献

8.更多讨论

1.背景介绍 什么是margin 什么是padding 我们在进行网页制作时都会遇到为元素设定边距的情况,边距又分为内边距和外边距,即margin和padding.

margin和padding是在html中的盒模型的基础上出现的,

margin是盒子的外边距,即盒子与盒子之间的距离,而padding是内边距,是盒子的边与盒子内部元素的距离。

2.知识剖析 margin是什么? CSS 边距属性定义元素周围的空间。通过使用单独的属性,可以对上、右、下、左的外边距进行设置。也可以使用简写的外边距属性同时改变所有的外边距。——W3School

边界,元素周围生成额外的空白区。“空白区”通常是指其他元素不能出现且父元素背景可见的区域。——CSS权威指南

padding是什么? padding 属性设置元素的内边距,属性定义元素边框与元素内容之间的空间。

同理padding可以称之为“内边距”,但是我又恰恰喜欢称呼padding为“补白”或者“留白”

Margin的特性 margin始终是透明的。margin通过使用单独的属性,可以对上、右、下、左的外边距进行设置。即:margin-top、margin-right、margin-bottom、margin-left。

margin只有一个值表示上右下左,如果 margin 只有两个值第一个值表示上下,第二个值为左右。

margin有三个值 表示上左右下,margin有四个值表示上下左右四个方向。

padding的特性 padding属性设置元素所有内边距的宽度,或者设置各边上内边距的宽度。行内非替换元素上设置的内边距不会影响行高计算;因此,如果一个元素既有内边距又有背景,

从视觉上看可能会延伸到其他行,有可能还会与其他内容重叠。元素的背景会延伸穿过内边距。不允许指定负边距值。

3.常见问题 1.什么是盒子模型。

2.margin和padding的区别。

3.用margin好还是用padding好。

4.解决方案 什么是盒子模型。

具备内容、填充、边框、边界这些属性,能包含其他元素的容器都是盒子。

margin和padding的区别。 我们以DIV为一个盒子为例,既然和现实生活中的盒子一样,那我们想一下,生活中的盒子内部是不是空的好用来存放东西,而里面存放东西的区域我们给他起个名字叫“content(内容)”,而盒子的纸壁给他起个名字叫“border(边框)”,如果盒子内部的东西比如是一块硬盘,但是硬盘怕震动,所以我们需要在硬盘的四周盒子的内部均匀填充一些防震材料,这时硬盘和盒子的边框就有了一定的距离了,我们称这部分距离叫“padding(内边距)”,如果我们需要购买许多块硬盘,还是因为硬盘怕震动所以需要在盒子和盒子之间也需要一些防震材料来填充,那么盒子和盒子之间的距离我们称之为"margin(外边距)"

用margin好还是用padding好 何时应当使用margin:

需要在border外侧添加空白时。

空白处不需要背景(色)时。

                上下相连的两个盒子之间的空白,需要相互抵消时。如15px + 20px的margin,将得到20px的空白。
复制代码

何时应当时用padding:

需要在border内测添加空白时。

空白处需要背景(色)时。

                上下相连的两个盒子之间的空白,希望等于两者之和时。如15px + 20px的padding,将得到35px的空白。
复制代码

margin在块级元素 margin在块级元素下,他的性能可以完全体现,上下左右任你设定.

margin在行级元素 margin也能用于内联元素,这是规范所允许的,但是margin-top和margin-bottom对内联元素(对行)的高度没有影响,并且由于边界效果(margin效果)是透明的,他也没有任何的视觉影响。

总结 margin属性可以应用于几乎所有的元素,除了表格显示类型。

padding属性的使用1.需要在border内测添加空白时。

                2.空白处需要背景(色)时。
复制代码

margin是用来隔开元素与元素的间距;padding是用来隔开元素与内容的间隔。margin用于布局分开元素使元素与元素互不相干;padding用于元素与内容之间的间隔,让内容(文字)与(包裹)元素之间有一段“呼吸距离”。

5.编码实战 6.扩展思考 什么是margin折叠? 在CSS中,两个或以上的块元素(可能是兄弟,也可能不是)之间的相邻外边距可以被合并成一个单独的外边距。通过此方式合并的外边距被称为折叠,且产生的已合并的外边距被称为折叠外边距。 处于同一个块级上下文中的块元素,没有行框、没有间隙、没有内边距和边框隔开它们,这样的元素垂直边缘毗邻,则称之为相邻。

7.参考文献 参考一:

                margin的详细用法
复制代码

参考二:

                怎么区分margin 和 padding的区别。
复制代码

参考三

                盒子模型知多少
复制代码

参考四

                margin为负值产生的影响和常见布局应用
复制代码

8.更多讨论 鸣谢 感谢大家观看

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

作者:menggx1
链接:https://juejin.im/post/5ae6b9516fb9a07aab29a14e
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

最新文章

  1. css选择器的使用详解
  2. jQuery通过parent()和parents()方法访问父级元素
  3. 在shell script中进行数值运算的两种方法
  4. iOS-性能优化2
  5. 【mybatis】1、入门CURD基本操作(环境搭建)
  6. C语言 链表的使用(链表的增删查改,链表逆转,链表排序)
  7. 理解Java的封装与接口
  8. 数据库的存储引擎和SQL语言
  9. Node.js包(JXcore)
  10. Unix/Linux环境C编程入门教程(30) 字符串操作那些事儿
  11. exception in thread main java.lang.NoClassDefFoundError wrong name解决方法
  12. Linux界面自动化测试框架不完全汇总
  13. TCP网络编程-----客户端请求连接服务器、向服务器发数据、从服务器接收数据、关闭连接
  14. hdu_1025(LIS Nlog(N)算法)
  15. RAC和单节点数据库的区别有哪些?RAC最有用的功能是什么?
  16. ubuntu安装Nginx
  17. FhqTreap的区间翻转
  18. 三数之和的golang实现
  19. 【Myeclipse】用Myeclipse10.5搭建C/C++开发环境
  20. Localization

热门文章

  1. 解决保存快照失败后redis无法写入的问题( Redis is configured to save RDB snapshots)
  2. delphi DLL image 动态绘图 句柄处理
  3. httpd启动显示Could not reliably determine the server's fully qualified domain name, using 127.0.0.1. Set the 'ServerName'
  4. H5如何测试?
  5. PyQt5学习一---环境的安装和配置
  6. Linux下安装redis-4.0.10
  7. tomcat 404 The origin server did not find a current representation for the target resource or is not willing to disclose that one exists.
  8. 安装docker-下载加速、失败、成功安装
  9. 【Linux开发】【Qt开发】arm-linux-gnueabihf-gdb versus gdb-multiarch
  10. [DS+Algo] 004 栈、队列及其代码实现