使用CSS的margin属性在页面布局中的使用攻略介绍

margin属性可以决定很多html元素的宽高度,因而在布局方面也能够有很重要的作用,接下来我们就来看一下使用css的margin属性在页面布局中的使用攻略介绍

基础

1.元素containing-box宽高度等于内容宽度

HTML

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

CSS

.wrap {      float: left;      border: 2px solid #000;    }   .item1 {      width: 100px;      height: 100px;      background: #fdf;      margin-left: 10px;      margin-top: 10px;      margin-right: 20px;      margin-bottom: 30px;   }   item2 {      width: 50px;      height: 50px;      background: #adf;   }

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

使用CSS的margin属性在页面布局中的使用攻略介绍

能满足原理1的条件只有一种,元素不设宽度且不在文档流中,此时,父元素wrap产生的containing-box的宽高宽度等子元素border-box的宽高度加上外边距的宽高度,也就是说,子元素的margin值也是其containing-box的一部分。margin一共有两类参考线,第一类是margin-top与margin-left的参考线,第二类是margin-bottom与margin-right的参考线,第一类margin的参考线是以其所处的containing-box的边缘线为参考线,如上例所示,当调整元素.item1的margin-top与margin-left的值时,元素.item1所处的containing-box的大小也在发生变化因此其边缘线也在不断变化同时也就导致.item1元素自身的位置也在发生变化,看起来就是.item1自身发生了移动。第二类margin的参考线是以元素自身的边缘线(外边距的外侧为边缘线)为参考线,同样的,调整上例中的margin-bottom值,.item1的margin-bottom也在不断的发生变化,也就是说其自身边缘线在不断的移动,同时导致了.item2的移动。根据上面的论述,我们可以得出结论,外边距的调整也就等于让其自身相对的参考线的位置在发生移动,同时导致相对于参考线运动的元素发生移动。元素自身相对于containing-box的边缘线移动而移动,与元素自身为兄弟关系的元素相对于元素自身的边缘线移动而移动。参考线示意图如图所示,按箭头所指方向使参考线变化的margin值都为正值。
综上,我们可以利用margin对元素自身进行移动,同时也可让其相邻元素进行移动,移动的同时我们需要知道的是其所处的containing-box的大小也在发生变化。
使用CSS的margin属性在页面布局中的使用攻略介绍

综上,当元素宽高度等于内容宽高度时,可通过调整内容的margin值来调整其containing-box的大小,因为containing-box的变化也就会导致元素本身的移动,也就是说既可以移动元素,也可调整元素与元素之间的间距。

2.元素内容宽度等于其containing-box的宽度

.wrap {       width: 100px;       border: 2px solid #000;       margin: 0 auto;   }   .wrap-inner {       height: 50px;       background: #fdf;   }

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

使用CSS的margin属性在页面布局中的使用攻略介绍

上例中,元素wrap-inner的border-box宽度加上margin的大小等于其containing-box的宽度,因此当containing-box宽度固定,根据公式’margin-left’ + ‘border-left-width’ + ‘padding-left’ + ‘width’ + ‘padding-right’ + ‘border-right-width’ + ‘margin-right’ = width of containing block,调整其自身margin-left或margin-right值,便会使wrap-inner自身大小发生变化,margin-left为正值且值逐渐变大,则wrap-inner自身宽度逐渐变小,若margin-left为负值且逐渐变小,则wrap-inner自身宽度逐渐变大,margin-right同理。一定要注意这里的宽度继承和width:100%是有本质区别的,因为width:100%就等于它的containing-box的100%和它的margin,border或者padding都木有关系,具体可看我的关于宽度与高度讨论的系列文章三里的例子,罗嗦了一点,但是这里是容易犯错误的地方。一定要注意,一定要注意,一定要注意!!!。重要的事情说三遍。

将margin-left和right调整为-10px,如图,根据计算,wrap-inner变宽
使用CSS的margin属性在页面布局中的使用攻略介绍

将margin-left和right调整为10px,如图,根据计算,wrap-inner变窄
使用CSS的margin属性在页面布局中的使用攻略介绍

综上,当元素宽或高度等于其containing-box的宽度或高度时,且containing-box的宽度固定我们便可以利用margin对其进行自身宽度大小的调整。也就是说宽高度和containing-box有关系时,我们利用margin可进行内里元素大小的调整。

不同元素margin的计算
行内级元素
Inline,非置换元素:如果margin值为auto,则margin-left和margin-right的计算值也就为0
Inline,置换元素:同上
Inline-block,置换元素在文档流中:同上
Inline-block,非置换元素在文档流中:同上
块级元素
块级非置换元素,在文档流中
‘margin-left’ + ‘border-left-width’ + ‘padding-left’ + ‘width’ + ‘padding-right’ + ‘border-right-width’ + ‘margin-right’ = width of containing block
下面的情况下,如果margin值为auto

如果width是auto值,那么其他值是auto的值就为0
如果margin-left和margin-right的值为auto,使用的值相等,那么就相对于包含块水平居中。
块级置换元素,在文档流中
同块级非置换元素一样。

小结
行内级置换元素和非置换元素,在margin值为auto时,margin-left和margin-auto的计算值都为0。
块级置换元素和非置换元素:
‘margin-left’ + ‘border-left-width’ + ‘padding-left’ + ‘width’ + ‘padding-right’ + ‘border-right-width’ + ‘margin-right’ = width of containing block
如果width是auto值,那么其他值是auto的值就为0
如果margin-left和margin-right的值为auto,使用的值相等,那么就相对于包含块水平居中。

利用Margin进行布局
通常在布局中我们会遇到那些问题呢?下面是我自己实践中遇到的一些问题

问题1
当我们拿到一份设计稿,然后这份设计稿有像下面这样的布局,整体居中,里面元素排一排,当然布局的方式会有很多种,那么如果我们采用浮动布局或者display:inline-block进行布局会出现什么问题呢,如图我们可以看出,若采用上述两种方式进行布局,那么每个块的宽度加上间隙,就会超出包含块的宽度,当然我们也可以将包含块的宽度进行增大以留下足够的位置供元素摆放,但是这种方法明显是不可取的,那么如何解决这个位置不够的问题呢,可以看下面的栗子1 。
使用CSS的margin属性在页面布局中的使用攻略介绍

栗子
html

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

css

body {     margin: 0;   }   .container {     margin: 0 auto;     width: 980px;   }   .inner-wrap {     margin-left: -10px;   }   .inner {     float: left;     margin-left: 10px;     width: 320px;     height: 200px;     background: #2df;   }

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

此布局便利用了原理2,利用负margin增加了inner-wrap的宽度,但不改变整体的宽的情况下,实现效果。如下
使用CSS的margin属性在页面布局中的使用攻略介绍

问题2
上面的例子仅仅只是实现了三列固定宽度的布局,这样的布局当屏幕宽度发生变化的时候便会出现问题。因此我们便会有如下需求。

左右列固定,中间列自适应

栗子
html

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

css

.main {     float: left;     width: 100%;   }   .main-content {     height: 200px;     background: #2da;     margin: 0 200px;   }   .left,.rightright {     float: left;     width: 200px;     height: 200px;     background: #ccc;   }   .left {     margin-left: -100%;   }   .rightright {     margin-left: -200px;   }

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

效果如下,当你缩小屏幕时,中间部分会随着屏幕的缩小而缩小,另外两部分宽度不变,同样也满足了主要内容优先加载的需求,可谓一举两得
使用CSS的margin属性在页面布局中的使用攻略介绍

分析:

可以看出上面的布局利用了原理2,但是这里仍然会有几个为什么要问。

首先,为什么main里面一定要嵌套main-content,为什么不能直接使用单个main(假设1)?
其次,为什么main上一定要设置float:left,可以设置其他值吗,如position:absolute(假设2)?
分析上面的布局之前,我们也要了解到上面的布局满足了我们的什么需求,这里有两点1.主要内容优先加载。2.主要内容自适应。这里我们可以分析一下,我们是怎样达到上述两个目的的。首先,要达到目的1,我们就的把p.main放在前面来写,因为浏览器是从下到下渲染页面的,放在前面的也就会先渲染。且由于p.main为文档流中的块级元素,因此会独占一行,因此我们需要使其脱离文档流,这样才能使下面的元素能有机会上的来(这里之所以不考虑display:inline-block是因为p.main的长度会独占一行,就算设置display:inline-block也没有任何作用,下面的元素仍然上不来)。而要达到目的2,需要用到原理2。同时在上面提出的两个问题中,有两个假设。

假设1,如果使用单个main可不可以满足上述两个需求?我们可以试试。
html

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

css

body {     margin:0;   }   /*这里注意需要改掉main的流方式,下面的元素才上的来*/.main {     float:left  margin: 0 210px;     height: 200px;     background:#2da;   }   .left,.rightright {     float: left;     width: 200px;     height: 200px;     background: #ccc;   }   .left {     margin-left: -100%;   }   .rightright {     margin-left: -200px;   }

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

使用CSS的margin属性在页面布局中的使用攻略介绍

从中线分开的黄色两部分为各自为main的左右外边距

从结果中,我们可以看出使用单个main是不行的,因为在不设宽度且元素不在文档流中时,元素的宽度为0,不能满足我们的需求,正因为我们同时要满足1.main元素不在文档流中2.元素不设宽度且在文档流中。这两个条件当然是不能同时在一个main元素下能达到的,因此我们需要再嵌套一个main-content让它来满足条件2。这也就解释了为什么一定要嵌套一个main-content。
解决了问题1,现在我们来说问题2。

假设2,main上的float值可以换为position:absolute吗?
同样的,我们试试
html

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

css

body {     margin: 0;   }   .main {     position:absolute;     width:100%;   }   .main-content {     margin: 0 210px;     height: 200px;     background: #2da;   }   .left,.rightright {     width: 200px;     height: 200px;     background:#ccc;   }   .left {     float: left;   }   .rightright {     float: rightright;   }

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

答案是可以的,只是我们需要改掉一些值,而当main为float之所以要给p.left与p.right要设置margin-left值是因为浮动元素浮动时,当它的外边缘碰到包含框或者另一个浮动框的边框为止。而为浮动元素的p.main占据了整整一行,因此下面的浮动元素p.left与p.right便被挤了下来,而设置它们的margin-left值便可以把它们移上去,这里便运用了原理1。而当我们把p.main的float值改为position:absolute时,便不会存在被挤下来的问题,可直接设置p.left与p.right的float的值。效果如下。
使用CSS的margin属性在页面布局中的使用攻略介绍

如若只需要达到宽度自适应的要求,那么,这时候便可以将p.main放在最后面且不用嵌套p.main-content,具体如何实现,大家可以自己试试。
问题3
如下所示设计稿,在我们进行布局的过程中,可能会出现border重合的情况,因为一方面我们需要对整个整体加上border,而另一方面我们又需要利用border隔开那三个小块。那么如果我们对每个小块都加上右边框,可以想象,最右边就会出现边框的堆叠而这不是我们希望看到的,所以,要如何解决这个问题,可以看如下例子给出的答案。
使用CSS的margin属性在页面布局中的使用攻略介绍

栗子
html

  • 1
  • 2
  • 3

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

css

ul {     position:absolute;     margin: 0;     padding:0;     list-style:none;     border: 4px solid #c5c5c5;   }   li {     float:left;     width: 200px;     height: 50px;     line-height: 50px;     text-align: center;     border-right: 4px solid #c5c5c5;   }

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

没在li上加margin-right:-4px;前,效果如图,发生了堆叠。
使用CSS的margin属性在页面布局中的使用攻略介绍

加了margin-right: -4px后,达到预期效果。因为加上了ul的右边框发生了移动与第三个li的右边框进行了重叠。因此效果上来看便符合了预期,如图
使用CSS的margin属性在页面布局中的使用攻略介绍

此布局便利用了原理1,通过元素对相邻元素位置的控制来达到预期的效果。
而利用原理1也可以实现元素居中的布局,先让元素上左各移50%,然后再让设置元素的上左margin值设置为元素自身宽度的一半长度,以对元素本身进行移动。便可达到元素居中放置的目的。

总结
1.元素宽度等于containing-box宽度时。
可以通过调整margin的值来调整元素的宽度。
2.元素宽度与containing-box无关时。
可以通过调整margin的值来移动元素的位置。

以上就是使用CSS的margin属性在页面布局中的使用攻略介绍的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1607832.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 21:11:19
下一篇 2025年12月23日 21:11:35

相关推荐

  • css实现3D立方体旋转特效的示例代码

    这篇文章介绍css实现3d立方体旋转特效的示例代码 先来看运行后出来的效果 它是在不停运行的一个立方体 立即学习“前端免费学习笔记(深入)”; 先来看html部分的代码 先建出来六个p然后再依次给它们设置样式 再来看它们的样式表 .rect-wrap { position: relative; pe…

    2025年12月23日
    000
  • 详解CSS中的clear清除浮动技巧

    下面小编就为大家带来一篇详解css中的clear清除浮动技巧。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 1、CSS中的clear有四个参数: none:允许两边都可以浮动。 left:不允许左边有浮动。 right:不允许右边有浮动。 立即学习“前端免费学习笔记(…

    2025年12月23日
    000
  • 详解CSS在固定宽高的div内实现垂直居中的实例分享

    这篇文章主要介绍了css在固定宽高的p内实现垂直居中的实例详解,即在p内部元素相对于p垂直居中的方法,需要的朋友可以参考下 需求案例 案例是这样的,一个外层p,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个padding或者margin,这样,里面内容显得貌似是居中了,但是假如内容…

    好文分享 2025年12月23日
    000
  • 分享CSS两列布局实现方式的总结

    这篇文章主要介绍了css两列布局实现方式的总结,讨论了包括absolute + margin和float + margin方式的一些实践和问题,需要的朋友可以参考下 两列布局大概是最经典的一种网页布局方式了,本博客就是采用的这种布局。两列布局中,以主列(main)是自适应宽度,子列(sidebar)…

    好文分享 2025年12月23日
    000
  • CSS3 animation实现逐帧动画效果示例介绍

    这篇文章主要介绍了css3 animation实现逐帧动画效果示例介绍,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 css3里面的animation属性非常强大,但是自己用的比较少,最近有次面试就刚好被问到了,趁现在有时间就对animation做一个小总结。同时实现一个逐帧动画的demo作为练…

    2025年12月23日 好文分享
    000
  • css全屏背景图片设置django加载图片路径详细说明

    下面小编就为大家带来一篇css全屏背景图片设置,django加载图片路径详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css全屏背景图片设置,django加载图片路径详解 #bg { position:fixed; top:0; left:0; width:10…

    好文分享 2025年12月23日
    000
  • 移动端Web页面的CSS3 flex布局学习指南

    flexbox通常能让我们更好的操作他的子元素布局,这里稍微来提炼一下移动端web页面的css3 flex布局学习指南,需要的朋友可以参考下 1、开始使用flexbox布局的方法,代码如下: footer{ display:flex; } 立即学习“前端免费学习笔记(深入)”; 2、接下来为foot…

    好文分享 2025年12月23日
    000
  • CSS的Display属性可能的值的说明

    下面小编就为大家带来一篇浅谈CSS的Display属性可能的值。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧none 此元素不会被显示。 block 此元素将显示为块级元素,此元素前后会带有换行符。 inline 默认。此元素会被显示为内联元素,元素前后没有换行符。 …

    好文分享 2025年12月23日
    000
  • CSS样式之背景、文本的详细介绍

    一、背景 1、背景颜色用background-color属性,例如:body{background-color:red} 2、用图像做背景用background-image属性,例如body{background-image:ul1(23.jpg) 3、背景由图片重复平铺用backgroud-rep…

    好文分享 2025年12月23日
    000
  • CSS单位和值与样式设置技巧分享

    一、单位和值    1.1 颜色值   在网页中的颜色设置是非常重要,有字体颜色(color)、背景颜色(background-color)、边框颜色(border)等,设置颜色的方法也有很多种:   1、英文命令颜色   前面几个小节中经常用到的就是这种设置方法: p{color:red;}   …

    2025年12月23日
    000
  • 分享纯CSS实现鼠标悬停显示图片效果的实例

    这里来给大家推荐一个纯css实现鼠标悬停显示图片效果的实例分享,以针对鼠标移到tr标签上来添加hover这种最简单的方式来演示,简单明了,需要的朋友可以参考下 最近在做一个网盘的项目,用到了鼠标移上去效果,这个效果可以用js来实现,今天主要分享一下,这个效果如何用纯css实现! 效果如下图: htm…

    2025年12月23日
    000
  • 浅谈css清除浮动clearfix和clear的用法介绍

    下面小编就为大家带来一篇浅谈css清除浮动(clearfix 和clear)的用法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 本文主要是讲解如何在 html 中使用 clearfix 和 clear,针对那些刚开始了解 css 的童鞋。关于 clearfix 和 …

    好文分享 2025年12月23日
    000
  • 详解CSS中的percentage百分比值使用方法

    一起来了解css中的percentage百分比值使用方法 百分比值是CSS中设计各种元素尺寸以及页面布局的基础手段,这里就带大家来彻底掌握CSS中的percentage百分比值使用,包括percentage转px的方法等,here we go~ 百分比旨在相对于父元素的相同属性的大小。如果用来设置字…

    2025年12月23日
    000
  • CSS中的选择器优先级顺序的详细介绍

    特殊性是什么 在对一个HTML元素应用CSS样式时,常常有很多种方法可以找到元素,比如: 这是一个段落 #container p { color:red } p p { color:green } p { color:yellow } 可见,如果要作用到一个HTML元素的方法有很多,远远不止这些。那…

    好文分享 2025年12月23日
    000
  • 在CSS中Box Model盒模型中的边距图文详解

    盒模型由以下css属性组成: 0.内容(content)1.padding 内边距2.border 边框3.margin 外边距下面有一个最常见的例子,虚线不属于盒模型,用于标识范围。 .box { width: 200px; height: 200px; background-color: gre…

    2025年12月23日
    000
  • 详解Less框架中将CSS强制打包到单个文件中的技巧

    在使用less预编译框架时我们总是希望能高效管理css文件的部署结构,这里我们就来看一个在less框架中将css强制打包到单个文件中的技巧,需要的朋友可以参考下 less 在import 其它less文件的时候会将其合并到单个文件中。但是当引入css 文件时,默认不会将css 合并进来 。使用inl…

    好文分享 2025年12月23日
    000
  • CSS的box-align属性控制子元素布局实例分析

    box-align 说明 box-align属性, 指定元素内子要素纵方向排列指定时使用。容器元素比子元素大很多的情况下,使用box-align属性,可以指定子元素的排序顺序,并且可以指定子元素如何表示。还有,纵方向排列一说,可以解释为元素内子元素的配置方向默认值为水平,使用此属性后垂直方向进行排列…

    2025年12月23日
    000
  • 详解CSS绘制三角形箭头图案技术解析

    最近我想修改一下这个网站,我想在上面放置一个提示框。这是很容易,但我想让提示框上有一个三角形的箭头。可是,一想到这需要使用图片,并且各种颜色,各种方向的箭头要准备无数种,这几乎是一种灾难。幸运的是,mootools的核心开发着darren waddell告诉了我一个非常棒的技术:用css绘制三角形箭…

    好文分享 2025年12月23日
    000
  • CSS实现商品图片点击放大效果的方法

    本文实例为大家分享了纯css实现图片点击放大带关闭按钮的图片特效代码,效果非常棒,供大家参考,具体内容如下 源码下载、演示 实现代码: CSS代码: .product { width:320px; height:150px; border:1px solid #ddd; margin:0 auto;…

    2025年12月23日
    000
  • 使用CSS的@supports标记来检测浏览器的兼容情况分析

    @supports可以用来检查浏览器是否支持某css属性,并且可以通过javascript进行控制,以下就来详细说明使用css的@supports标记来检测浏览器的兼容情况的方法 CSS @supports标记在CSS代码里跟@media查询语句的语法相似: @supports(prop:value…

    好文分享 2025年12月23日
    000

发表回复

登录后才能评论
关注微信