CSS布局的实用小技巧:margin负值

CSS布局的实用小技巧:margin负值

负边距即margin属性的值设为负值,在CSS布局中时一个很有用的技巧。值为正的场景很常见,大家都很熟悉其表现

当margin-top、margin-left为负值的时候,会把元素上移、左移,同时文档流中的位置也发生相应变化,这点与position:relative的元素设置top、left后元素还占据原来位置不同

当margin-bottom、margin-right设为负值的时候,元素本身没有位置变化,后面的元素会下移、右移

看几个应用场景

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

绝对定位元素

当元素被设置为绝对定位的时候其top、right、bottom、left值是指离最近的非static元素的距离,经典的垂直居中的一种方式正是利用的绝对定位元素的负边距实现的

.wrap4{position:relative;margin:10px;width:200px;height:200px;border:dashed 1px orange;}.wrap4 .content{position:absolute;width:100px;height:100px;top:50%;left:50%;margin-top:-50px;margin-left:-50px;background:orange;}

把元素设置为绝对定位,然后设置top和left为50%,这时候元素的上边、左边就到了父元素的50%处,再对元素设置其自身高度、长度一般的负边距,使元素中心移动到父元素中心,实现居中对齐

1.png

float元素

负边距对float元素的影响也是按照上面说的,不过有其特殊性,我们看个例子就很清楚了

浮动元素负边距

.float{overflow:hidden;width:280px;border:dashed 1px orange;}.float .item{width:100px;height:100px;float:left;}.float .item:nth-child(1){background:red;}.float .item:nth-child(2){background:grey;}.float .item:nth-child(3){background:blue;}

在一个宽度为280px的div中右3个float:left的子元素,宽度为100px,由于一排放不下,最后一个陪移动到了下一行

2.png

我们对代码稍作修改

.float{overflow:hidden;width:280px;border:dashed 1px orange;}.float .item{width:100px;height:100px;float:left;}.float .item:nth-child(1){background:red;}.float .item:nth-child(2){background:grey;}.float .item:nth-child(3){background:blue;margin-left:-20px;}

第三个元素添加-20px的负边距

3.png

这时候发现第三个元素移上去了,并且覆盖了第二个元素20px,经典的多列布局正是利用此原理

多列布局

.body{width:500px;margin:10px;border:dashed 1px orange;overflow:hidden;}.wrap3{float:left;width:100%;}.wrap3 .content{height:200px;margin-right:100px;background:rgba(255,0,0,0.5);}.body .right{width:100px;height:200px;float:left;margin-left:-100px;background:rgba(0,255,0,0.5)}
Content Content Content Content Content Content Content Content Content Content Content Content Content Content Content
Right

代码很简单

为content元素添加父元素,设置左浮动,宽度100%

content元素设置右边距,值等于right的宽度

right左浮动,然后设置其宽度的负边距

本来right应该在第二行显示了,但是其宽度的左浮动使它到了第一行的最右边,覆盖了wrap的一部分,但是content有right宽度的右边距,覆盖区域没有内容,这样就实现了两列布局

4.png

普通元素

负边距对不同块元素的影响很有意思,我们通过几个例子来看一下

多列列表

li{line-height:2em;}.col2{margin-left:150px;}.col3{margin-left:300px;}li.top{margin-top:-9em;}
  • aaa
  • bbb
  • ccc
  • ddd
  • eee
  • fff
  • ggg
  • hhh
  • iii

普通的做法我们肯定是通过浮动实现,通过刚才介绍的知识应该不难理解为什么这样也行。看起来在普通元素上没什么稀奇的

放大元素

什么?负边距还可以放大元素!!!

.wrap{width:300px;border:dashed 5px orange;}.wrap .inner{height:50px;margin:0 -50px;background:blue;opacity:0.5;}
inner inner inner inner inner inner inner inner inner inner inner inner

这个例子看起来平淡无奇,效果却很惊人,内层的div设置了水平的负边距后竟然变大了

5.png

PS. 效果能实现的前提是元素的宽度不能设置为auto以外的值

带有右边距的浮动子元素列表

6.png

看到这种效果你第一想法是什么?会不会是子元素设置margin-right,在遍历的时候nth-child(3n)还要设置为0,看看利用上面知识我们可以怎样处理

.wrap2{width:320px;border:dashed 1px orange;}.wrap2 .inner{  overflow:hidden;  margin-right:-10px;}.wrap2 .item{float:left;width:100px;height:100px;margin:10px 10px 10px 0;background:blue;}

我们没有设置nth-child(3n)的边距为0,而是通过负边距使父元素“变大”。

负边距是不是很有意思,不很了解的少年们学起来吧!

更多编程相关知识,请访问:编程学习!!

以上就是CSS布局的实用小技巧:margin负值的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 05:19:31
下一篇 2025年12月24日 05:19:42

相关推荐

  • CSS什么是圣杯布局?

    在CSS中,圣杯布局是指两边盒子宽度固定,中间盒子自适应的三栏布局,其中,中间栏放到文档流前面,保证先行渲染;三栏全部使用“float:left”浮动,并配合left和right属性。 前端的两个经典布局想必大家都有多了解–圣杯布局和双飞翼布局,因为它既能体现你懂HTML结构又能体现出你…

    2025年12月24日 好文分享
    000
  • css怎么去掉字体粗体样式

    css去掉字体粗体样式的方法:可以利用font-weight属性来实现,如【font-weight:normal;】。font-weight属性用于设置文本的粗细,normal用于定义标准的字符。 本教程操作环境:windows10系统、css3,本文适用于所有品牌的电脑。 属性介绍: font-w…

    2025年12月24日
    000
  • css属性为什么要加前缀

    css属性加前缀的原因:虽然浏览器厂商以前就一直在实施css3,但它还并未成为真正的标准。因此当一些css3样式语法存在波动时,它们就需要提供针对浏览器的前缀。 原因分析: 虽然浏览器厂商以前就一直在实施CSS3,但它还未成为真正的标准。为此,当一些CSS3样式语法还存在波动时,它们就需要提供针对浏…

    2025年12月24日
    000
  • css外链式和导入式的区别是什么

    css外链式和导入式的区别是:外链式是先将css布局文件加载到网页文件中,而导入式是先加载网页文件,然后再加载布局文件。使用导入式可以避免过多的网页文件指向一个css布局文件。 区别分析如下: (学习视频推荐:css视频教程) 外链式样式 导入式样式 立即学习“前端免费学习笔记(深入)”; @imp…

    好文分享 2025年12月24日
    000
  • css如何设置字体下划线

    css设置字体下划线的方法:可以利用text-decoration属性来进行设置,如【text-decoration: underline;】。text-decoration属性用于规定添加到文本的修饰、下划线、上划线、删除线等。 属性介绍: text-decoration 属性规定添加到文本的修饰…

    2025年12月24日
    000
  • css如何设置黑体样式

    css设置黑体样式的方法:可以利用font-family属性来进行设置,如【font-family: 黑体;】。font-family属性用于指定一个元素的字体。 属性介绍: font – family属性指定一个元素的字体。 (学习视频分享:css视频教程) 有两种类型的字体系列名称:…

    2025年12月24日
    000
  • css中的display是什么意思

    css中的display是用于规定应该生成的框的类型的属性。对于html等文档类型,必须谨慎使用display属性,否则可能会违反html中已经定义的显示层次结构。 属性介绍: display 属性规定元素应该生成的框的类型。 对于 HTML 等文档类型,如果使用 display 不谨慎会很危险,因…

    2025年12月24日
    000
  • css怎么设置段落缩进

    css设置段落缩进的方法:可以利用text-indent属性来进行设置,如【text-indent:36px;】。text-indent属性用于规定文本块中首行文本的缩进。 相关属性: text-indent 属性规定文本块中首行文本的缩进。 注意:负值是允许的。如果值是负数,将第一行左缩进。 (学…

    2025年12月24日
    000
  • 使用css有什么优势

    使用css的优势有:1、内容与表现分离;2、网页的表现统一,容易修改;3、丰富的样式,使页面布局更加灵活;4、减少网页的代码量,增加网页的浏览速度;5、有利于网页被搜索引擎收录。 优势: (学习视频分享:css视频教程) 1、内容与表现分离 2、网页的表现统一,容易修改 立即学习“前端免费学习笔记(…

    2025年12月24日
    000
  • css怎么设置超链接字体加粗效果

    css设置超链接字体加粗效果的方法:1、创建一个a标签;2、在style标签中,使用标签选择器选择所有的超链接;3、给a标签设置font-weight样式即可,如【a{font-weight: bold;}】。 相关属性: font-weight 属性设置文本的粗细 (学习视频推荐:css视频教程)…

    2025年12月24日
    000
  • css怎么设置鼠标变背景

    css设置鼠标变背景的方法:首先打开相应的前端代码文件;然后设置样式为“.logo-link {background-image:url(…);}.logo-link:hover,.logo-link:active {}”即可。 推荐:《css视频教程》 CSS代码实现鼠标移过更换背景图…

    2025年12月24日
    000
  • css三个字如何和两个字对齐

    css实现三个字和两个字对齐的方法:首先创建一个HTML示例文件;然后给指定div添加“text-align: justify”等样式即可实现三个字和两个字对齐。 推荐:《css视频教程》 需求如下,红框所在的文字有四个字的、三个字的、两个字的,如果不两端对齐可以选择居中对齐,或者右对齐。但是如果要…

    2025年12月24日 好文分享
    000
  • css伪类分为哪几种

    css伪类分为UI伪类和结构化伪类两种。UI伪类分为链接伪类、focus伪类和target伪类。结构化伪类分为【:first-child】、【:last-child】和【:nth-child】。 CSS伪类分两种: 1、UI伪类:会在HTML元素处于某种状态时(比如鼠标指针位于连接上),为该元素应用…

    2025年12月24日
    000
  • css什么时候清除浮动

    在css中,当我们对元素进行float浮动时就需要清除浮动,因为当元素进行浮动时,元素就会脱离文档流;并且在css中任何元素都可以浮动,浮动元素会生成一个块级框,而不论它本身是何种元素。 推荐:《css基础教程》 清除浮动,什么时候需要清除浮动,清除浮动都有哪些方法 ? 一.什么时候需要清除浮动? …

    2025年12月24日 好文分享
    000
  • css怎么在图片上加阴影

    css在图片上加阴影的方法:可以利用box-shadow属性来添加阴影,如【box-shadow: 10px 10px 10px rgba(0,0,0,.5);】。box-shadow属性可以设置一个或多个下拉阴影的框。 属性介绍: box-shadow属性可以设置一个或多个下拉阴影的框。 (学习视…

    好文分享 2025年12月24日
    000
  • css怎么给图片加上下边框

    css给图片加上下边框的方法:可以利用border-top属性和border-bottom属性来添加上下边框,如【border-bottom:thick dotted;border-top:thick double;】。 border-bottom 简写属性把下边框的所有属性设置到一个声明中。 (学…

    2025年12月24日
    000
  • css文件中引用图片不显示怎么办

    css文件中引用图片不显示的解决方法:1、确保图片路径书写正确;2、设置图片成块显示;3、指定图片的宽和高。正确代码如:【display:block;width: 25px;height: 21px;】。 解决思路: 1、确保路径正确 2、成块显示 3、指定宽高 立即学习“前端免费学习笔记(深入)”…

    2025年12月24日
    000
  • css列表怎么横着排列

    css列表横着排列的方法:可以利用【display:inline】属性把【】标签设定为内联元素来实现横向排列效果。display属性规定了元素应该生成的框的类型。 思路: 设定 标签的display:inline,把设定为内联元素来实现横向排列的效果。 (推荐教程:css视频教程) 属性介绍: 立即…

    2025年12月24日
    000
  • css怎么才能让字等距分开

    css让字等距分开的方法:可以利用letter-spacing属性来实现,如【letter-spacing:10px;】。letter-spacing属性用于增加或减少字符间的空白(字符间距)。 letter-spacing 属性增加或减少字符间的空白(字符间距)。 (视频教程推荐:css视频教程)…

    2025年12月24日
    000
  • CSS中link什么意思

    CSS中link是指CSS链接,不同的链接可以有不同的样式,而链接的样式可以用任何CSS属性,其链接状态有4种,分别是:1、“a:link”;2、“a:visited”;3、“a:hover”;4、“a:active”。 本教程操作环境:windows10系统、css3,本文适用于所有品牌的电脑。 …

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信