CSS中的padding和margin属性怎么使用
本文小编为大家详细介绍"CSS中的padding和margin属性怎么使用",内容详细,步骤清晰,细节处理妥当,希望这篇"CSS中的padding和margin属性怎么使用"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
CSS中padding、margin两个重要属性的详细介绍及举例说明
注: 为什么不翻译margin和padding? 原因一, 在汉语中并没有与之相对应的词语; 原因二: 即使有这样的词语, 由于在编写CSS代码时, 必须使用margin和padding, 如果我们总用汉语词语代替其来解释的话, 到了实际应用时容易混淆margin和padding的概念。
以下说明margin和padding属性:
1. Margin: 包括margin-top, margin-right, margin-bottom, margin-left, 控制块级元素之间的距离, 它们是透明不可见的, 对于Fig. 2所示的上右下左margin值均为40px, 因此代码为:
margin-top: 40px; margin-right: 40px; margin-bottom: 40px; margin-left: 40px;
根据上, 右, 下, 左的顺时针规则, 简写为
margin: 40px 40px 40px 40px;
当上下, 左右margin值分别一致, 可简写为:
margin: 40px 40px;
前一个40px代表上下margin值, 后一个40px代表左右margin值.
当上下左右margin值均一致, 可简写为:
margin: 40px;
2. Padding: 包括padding-top, padding-right, padding-bottom, padding-left, 控制块级元素内部, content与border之间的距离, 其代码, 简写请参考margin属性的写法.
至此, 我们已经基本了解margin和padding属性的基本用法. 但是, 在实际应用中, 却总是发生一些让你琢磨不透的事, 而它们又或多或少的与margin有关.
注: 当你想让两个元素的content在垂直方向(vertically)分隔时, 既可以选择padding-top/bottom, 也可以选择margin-top/bottom, 再此Jorux建议你尽量使用padding-top/bottom来达到你的目的, 这是因为CSS中存在Collapsing margins(折叠的margins)的现象.
Collapsing margins: margins折叠现象只存在于临近或有从属关系的元素, 垂直方向的margin中. 文字说明可能让人费解, 下面用一个例子说明margin-collapsing现象.
例: 在html文件的之间写入如下代码:
Margins of ID1 and ID2 collapse vertically.
元素ID1与ID2的margins在垂直方向折叠.h2> div>在与其外联的CSS文件中写入:
* { padding:0; margin:0; } #ID1 { background-color: #333; color: #FFF; margin-top: 10px; margin-bottom: 10px; } #ID2 { font: normal 14px/1.5 Verdana, sans-serif; margin-top: 30px; margin-bottom: 30px; border: 1px solid #F00; }代码解释:
1. 在html写入的代码表示, 在html中插入id分别为ID1和ID2的两个块级元素div, h2;
2. *{padding:0; margin:0;}: 使浏览器默认的元素padding和margin值均归零;
3. #ID1{…}: 使id为ID1的元素div的背景颜色为#333, 字体颜色为#FFF, margin-top/bottom为10px;
4. #ID2{…}: 使id为ID2的元素h2的字体大小为14px, verdana字体, 行高为字体高的150%, 正常粗细. margin-top/bottom为30px, 边框为1px宽, 红色实线.
依据以上解释, 我们应该得到如下效果(Fig. 3):
即ID1的margin-top/bottom=ab=ef=10px;
ID2的margin-top/bottom=bc=de=30px;
但用浏览器打开html文件, 却得到Example4的效果, 如下图(Fig. 4):即ab=cd=30px, ID1的margin-top/bottom=10px被折叠了, 而且ID1应有的margin黑色背景也一同被折叠消失了。
◆为什么会折叠:
造成以上现象的原因是, 我们在CSS中并没有声明id为ID1的元素div的height(高), 因此它的高便被设为auto(自动)了. 一旦其值被设为auto, 那么浏览器就会认为它的高为子元素ID2的border-top到border-bottom之间的距离, 即Fig. 4中bc的长度, 所以子元素ID2的margin-top/bottom(30px)就伸出到了父元素ID1之外, 出现了Fig. 4中ab与cd之间的空白区域. 因此父元素ID1的margin-top/bottom因子元素的"红杏出墙"而被折叠消失了.
如何解决折叠问题: 可能大家最初想到的办法就是根据折叠发生的原因-auto, 来解决问题. 但是, 在实际操作中, 某些元素如div, h2, p等, 我们是不可能预先知道它的高是多少的, 因此在CSS文件中是不能常规通过声明元素的高来解决折叠问题.
我们需要在CSS文件中加入如下代码(红色部分):
#ID1 { background-color: #333; color: #FFF; margin-top: 10px; margin-bottom: 10px; padding-top:1px; padding-bottom:1px; }或是:
#ID1 { background-color: #333; color: #FFF; margin-top: 10px; margin-bottom: 10px; border-top:1px solid #333; border-bottom:1px solid #333; }通过增加以上代码, 便可使浏览器重新计算ID1的高, 使其为子元素ID2的margin-top/bottom外缘(outer top/bottom)之间的距离, 即Fig. 3中be的距离.
读到这里,这篇"CSS中的padding和margin属性怎么使用"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。
元素 代码 属性 之间 文件 原因 字体 浏览器 现象 简写 浏览 上下 两个 实际 文章 方向 词语 问题 解释 一致 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全预案预防工作包括 数据库进销存系统实验结果及说明 asp网页 数据库 地下城进不去显示服务器连接失败 家庭金融数据库分析 今年数据库管理工资 战舰世界连接服务器 顺网科技服务器 滨州网络安全检查 建立gis数据库需要多少钱 广州微商代理软件开发公司 新形式下的网络安全讲座心得 南京益环奎网络技术 蚌埠软件开发人才市场 oracle 数据库分页 计算机网络技术 简历 网络安全法未明确谁的职责 无锡锡山智能服务器维修 人才数据库证书管理系统 网络技术费用什么科目 中国网络安全是什么 网络安全铁人三项题库 网络安全法规定国家倡导 广东商联支付网络技术 数据库数据结构哪个难 配置php服务器 网络技术评职称 网络安全安全宣传周活动 数据库加密系统云部署 数据库中如何创建默认值