0

0

CSS marging浅析

php中文网

php中文网

发布时间:2016-07-21 14:53:01

|

2495人浏览过

|

来源于php中文网

原创

一、margin可以为负值

在盒模型中,内容区的width/height、padding、border都不能为负值,但是margin例外,它可以为负值。

关于margin负值的使用技巧,了解不多,日后有机会再补充,此处先贴两个经典应用。

1.    margin-left负值结合浮动实现不改变DOM结构的流体布局。

       (此demo与CSS float浅析篇中的是同一个。)

立即学习前端免费学习笔记(深入)”;

 1 DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title>不改变DOM结构的流体布局title>
 6         <style>
 7             .container {
 8                 width:600px;
 9                 margin-left: auto;
10                 margin-right: auto;
11                 background-color: orange;
12                 font-size: 16px;
13                 line-height: 1.5;
14             }
15 
16             .box1 {
17                 width:100%;
18                 float:left;
19             }
20 
21             .box2 {
22                 margin-right: 220px;
23                 padding-left: 20px;
24             }
25 
26             img {
27                 width:200px;
28                 float:left;
29                 margin-left:-200px;
30             }
31 
32             .clearfix:after {
33                 content: "";
34                 display: table;
35                 clear: both;
36             }
37 
38             .clearfix {
39                 *zoom: 1;
40             }
41 
42         style>
43     head>
44     <body>
45         <div class="container clearfix">
46             <div class="box1">
47                 <div class="box2">
48                 <h3>不改变DOM位置的流体布局h3>
49                 <p>假如有一段文本和一幅图像,在DOM节点中,文本在前,图像在后,怎么能把图像定位到右边呢?p>
50                 <p>通常的做法是,调换DOM节点中图像与文本的位置,让图像在前,文本在后,然后将图像浮动到右边即可。p>
51                 <p>但这样改变DOM节点顺序始终不妥,还有什么更好的方法呢?p>
52                 <p>下面就介绍一种新的思路来完成布局。p>
53                 <ul>
54                     <li>将文本用div包起来,定义为box1;现在的结构是一个box1和一个img。li>
55                     <li>将box1宽度设为100%,左浮动;将img设置一个宽度,也左浮动,然后margin-left设为负的宽度值;此时图像就定位到文本的右边啦。li>
56                     <li>但是有一个问题,图像盖住了文本内容,这可怎么办?li>
57                     <li>重点来了,在box1中增加一个box2,box2把文本全部包起来,然后margin-right设为图像的宽度(+额外的间距),这样就解决问题啦!li>
58                 ul>
59                 div>
60             div>
61             <img src="http://imgsrc.baidu.com/forum/w%3D580/sign=0c101fe665380cd7e61ea2e59145ad14/f9a3492762d0f7032de1758a08fa513d2797c542.jpg" alt="a picture" style="width:200px;height:300px" />
62         div>
63     body>
64 html>
View Code

 

2.    margin负值实现两列等高布局

 1 DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title>margin负值实现等高布局title>
 6         <style>
 7             div.container {
 8                 margin-left: 200px;
 9                 overflow: hidden;
10             }
11 
12             div.box {
13                 width:300px;
14                 float: left;
15                 margin-right: 20px;
16             }
17 
18             div.box1 {
19                 background-color: brown;
20                 margin-bottom: -9999px;
21                 padding-bottom: 9999px;
22             }
23 
24             div.box2 {
25                 background-color: green;
26                 margin-bottom: -9999px;
27                 padding-bottom: 9999px;
28             }
29 
30             p {
31                 margin-bottom: 50px;
32             }
33 
34         style>
35     head>
36     <body>
37         <div class="container">
38             <div class="box box1">
39                 <p>box1p>
40                 <p>box1p>
41             div>
42             <div class="box box2">
43                 <p>box2p>
44                 <p>box2p>
45                 <p>box2p>
46                 <p>box2p>
47                 <p>box2p>
48                 <p>box2p>
49                 <p>box2p>
50                 <p>box2p>
51             div>
52         <div class="container">
53     body>
54 html>
View Code

其实现原理为margin负值与padding正值相互抵消。 

 

二、margin的百分比数值

当margin属性的值为百分数时,其总是以父元素的width为基数进行计算。

CSS的特效赏析
CSS的特效赏析

CSS特效赏析

下载

请看下面这个demo,当初折磨了我N久的。。。只怪我知道得太晚了,说多了都是泪啊。。。

 1 DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title>margin的百分数值title>
 6         <style>
 7             .container {
 8                 width: 500px;
 9                 height: 300px;
10                 margin: 50px auto;
11                 background-color: orange;
12                 border: 1px solid black;
13             }
14 
15             .box {
16                 width: 250px;
17                 height: 150px;
18                 margin-left: auto;
19                 margin-right: auto;
20                 background-color: cyan;
21             }
22 
23             .box1 {
24                 margin-top: 75px;
25                 margin-bottom: 75px;
26                 padding: 5px;
27             }
28             
29             .box2 {
30                 margin-top: 25%;
31                 margin-bottom: 25%;
32                 padding: 5px;
33             }
34         style>
35     head>
36 
37     <body>
38         <div class="container">
39             <div class="box box1">
40                 <p>父元素的高度为300px,子元素的高度为150px,只要margin-top和margin-bottom都为75px,这个盒子就能垂直居中。p>
41                 <p>OK,居中啦!!!p>
42             div>
43         div>
44         <div class="container">
45             <div class="box box2">
46                 <p>既然子元素的高度是父元素高度的50%,那么只要margin-top和margin-bottom都为25%,应该也能垂直居中。p>
47                 <p>额,这什么鬼?说好的居中呢?p>
48             div>
49         div>
50     body>
51 html> 
View Code

 

三、垂直方向上margin的合并

这个问题经常造成一些困惑,不过只需要记住一句话即可,垂直方向上的margin只要亲密接触就会合并,也只有亲密接触才会合并。

垂直方向上margin的合并,如果发生在相邻元素,其实是很好理解的;但是如果发生在父元素与子元素之间,就有些怪异了。

来看例子:

 1 DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title>垂直方向上的margin合并title>
 6         <style>
 7             .container {
 8                 width: 500px;
 9                 height: 300px;
10                 margin: 50px auto;
11                 background-color: orange;
12             }
13 
14             .box {
15                 width: 300px;
16                 height: 200px;
17                 margin-left: auto;
18                 margin-right: auto;
19                 background-color: cyan;
20                 margin-top: 25px;
21                 padding: 5px;
22             }
23 
24             .border {
25                 border: 1px solid black;
26                 /*padding: 1px;*/
27             }
28         style>
29     head>
30 
31     <body>
32         <div class="container">
33             <div class="box">
34                 <p>父元素的margin-top为50px,子元素的margin-top为25px;p>
35                 <p>咦,子元素的margin-top呢?为什么都顶到父元素上边界了?p>
36                 <p>额,因为父元素与子元素的margin-top亲密接触了呀,所以它们合并在一起了啊。p>
37             div>
38         div>
39         <div class="container border">
40             <div class="box">
41                 <p>可是我就是想让子元素距离父元素的上边界25px啊,我不想让它们合并呀。p>
42                 <p>很简单,给父元素加个边框,它们就无法亲密接触了,就不会合并了啊。p>
43                 <p>或者给父元素设置padding也是可以的喔。p>
44             div>
45         div>
46     body>
47 html> 
View Code

消除垂直方向上margin合并的方法:给父元素加border或者加padding,打破父元素与子元素margin之间的亲密接触即可

 

margin合并的规则:

 1 DOCTYPE html>
 2 html>
 3     head>
 4         meta charset="utf-8">
 5         title>margin合并规则title>
 6         style>
 7             .container {
 8                 width: 300px;
 9                 height: 500px;
10                 margin: 50px;
11                 background-color: orange;
12                 float: left;
13                 border: 1px solid black;
14             }
15 
16             .box1,.box2,.box3,
17             .box4,.box5,.box6 {
18                 width: 200px;
19                 height: 150px;
20                 margin: 30px auto;
21                 background-color: cyan;
22                 text-align: center;
23                 line-height: 150px;
24             }
25 
26             .box1 {
27                 margin-bottom: 30px;
28             }
29 
30             .box2 {
31                 margin-top: 20px;
32             }
33 
34             .box3 {
35                 margin-bottom: 30px;
36             }
37 
38             .box4 {
39                 margin-top:

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

15

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

12

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

546

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

194

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

330

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

11

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

16

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

11

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
李炎恢bootstrap视频教程
李炎恢bootstrap视频教程

共26课时 | 9.9万人学习

webpack+vue—从零开始打造前端项目
webpack+vue—从零开始打造前端项目

共47课时 | 5.9万人学习

CSS深入浅出视频教程
CSS深入浅出视频教程

共48课时 | 10万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号