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;}

登录后复制aaabbbcccdddeeefffggghhhiii

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

放大元素

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

.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负值的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2883560.html

(0)
上一篇 2025年3月10日 20:20:33
下一篇 2025年2月25日 16:08:23

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css中字体常用单位有哪些?

    css中字体常用单位有:1、px(像素),是固定大小的单位;2、em,相对长度单位,相对于父级元素的字体大小;3、rem,相对长度单位,是相对于根节点(或者是html节点)的字体大小;4、%,相对长度单位,相对于父级元素。 本教程操作环境:…

    2025年3月10日 编程技术
    200
  • css如何设置字体为微软雅黑

    css设置字体为微软雅黑的方法:可以利用font-family属性来设置,如【font-family:”微软雅黑”】或【font-family:”Microsoft YaHei”;】。 相关属…

    2025年3月10日
    200
  • css如何实现圆形头像

    css实现圆形头像的方法:可以通过直接设置img为圆形的方式来实现,如【border-radius: 30px;】。需要注意的是使用这种方式如果图片不是正方形,那么图片会被拉伸。 可以通过如下两种方式来实现: 方法一:直接设置img为圆形,…

    2025年3月10日
    200
  • css层叠样式表是什么

    css层叠样式表是一种用来表现HTML或XML等文件样式的计算机语言。css能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式。 层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现HTM…

    2025年3月10日
    200
  • css如何设置下划线为虚线

    css设置下划线为虚线的方法:可以利用text-decoration-style属性来进行设置,如【text-decoration-style: dotted;】。text-decoration-style属性用于规定线条如何显示。 相关属…

    2025年3月10日
    200
  • “margin:0 atuo;”是什么意思?

    “margin:0 atuo;”代表的意思是“水平居中”。css margin属性设置对象外边距,如果值只有两个参数的话,第一个表示上下边距,第二个表示左右编辑;因为0 auto,表示上下边界为0,左右则根据宽度自适应相同值(即水平居中)。…

    2025年3月10日
    200
  • css怎样设置图片之间的间隔

    css设置图片之间的间隔的方法:首先新建一个html文件,并创建一个div;然后在div内使用img标签创建两张图片;最后使用margin属性设置两张图片之间的距离即可。 本教程操作环境:windows10系统、css3,本文适用于所有品牌…

    2025年3月10日 编程技术
    200
  • css如何改变文本框颜色

    css改变文本框颜色的方法:可以利用border-color属性来改变文本框颜色,如【border-color:#0000ff;】。border-color属性用于设置一个元素的四个边框颜色。 相关属性: border-color属性设置一…

    2025年3月10日
    200
  • css怎么设置字体为宋体

    css设置字体为宋体的方法:可以利用font-family属性来进行设置,如【font-family: 宋体;】或【font-family: SimSun;】。font-family属性用于指定一个元素的字体。 相关属性: font &#8…

    2025年3月10日
    200
  • css属性选择器有什么用?

    css的属性选择器可以查找具有特定属性或特定值属性的元素,即可以通过已经存在的属性名或属性值来匹配HTML元素,然后对带有指定属性的HTML元素设置样式。 在HTML中的元素都可以具有属性,这些属性是显示或修改其行为的附加值。html中包含…

    2025年3月10日 编程技术
    200

发表回复

登录后才能评论