负边距在布局中的使用

简介:

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

  • margin-topmargin-left为负值的时候,会把元素上移、左移,同时文档流中的位置也发生相应变化,这点与position:relative的元素设置top、left后元素还占据原来位置不同
  • margin-bottommargin-right设为负值的时候,元素本身没有位置变化,后面的元素会下移、右移

看几个应用场景

绝对定位元素

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

<style>
.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;
}
</style>

<div class="wrap4">
    <div class="content"></div>
</div>

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

float元素

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

浮动元素负边距

<style>
.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;
}
</style>

<div class="float">
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
</div>

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

我们对代码稍作修改

<style>
.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;
}
</style>

<div class="float">
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
</div>

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

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

多列布局

<style>
.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)
}
</style>

<div class="body">
    <div class="wrap3">
        <div class="content">
            Content Content Content Content Content Content Content 
            Content Content Content Content Content Content Content Content
        </div>
    </div>
    <div class="right">Right</div>
</div>

代码很简单

  1. 为content元素添加父元素,设置左浮动,宽度100%
  2. content元素设置右边距,值等于right的宽度
  3. right左浮动,然后设置其宽度的负边距

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

Content Content Content Content Content Content Content Content Content Content Content Content Content Content Content
Right

PS. 其它此类更复杂的布局原理类似,感兴趣的同学可以看这里学40种。。。

普通元素

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

多列列表

<style>
li{
    line-height:2em;
}

.col2{
    margin-left:150px;
}

.col3{
    margin-left:300px;
}

li.top{
    margin-top:-9em;
}
</style>

<ul>
    <li class="col1">aaa</li>
    <li class="col1">bbb</li>
    <li class="col1">ccc</li>
    <li class="col2 top">ddd</li>
    <li class="col2">eee</li>
    <li class="col2">fff</li>
    <li class="col3 top">ggg</li>
    <li class="col3">hhh</li>
    <li class="col3">iii</li>
</ul>

定义一个列表,三列显示

  • aaa
  • bbb
  • ccc
  • ddd
  • eee
  • fff
  • ggg
  • hhh
  • iii

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

放大元素

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

<style>
.wrap{
    width:300px;
    border:dashed 5px orange;
}

.wrap .inner{
    height:50px;
    margin:0 -50px;
    background:blue;
    opacity:0.5;
}
</style>

<div class="wrap0">
  <div class="inner0">
    inner inner inner inner inner inner inner inner inner inner inner inner 
  </div>
</div>

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

inner inner inner inner inner inner inner inner inner inner inner inner inner

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

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

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

<style>
.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;
}
</style>

<div class="wrap2">
    <div class="inner">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
  </div>
</div>

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

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



    本文转自魏琼东博客园博客,原文链接:http://www.cnblogs.com/dolphinX/p/4071725.html,如需转载请自行联系原作者

相关文章
|
数据挖掘
深入分析:ERP系统的优势与劣势
深入分析:ERP系统的优势与劣势
1044 3
|
机器学习/深度学习 人工智能 数据可视化
【2024美赛】C题 Momentum in Tennis网球运动中的势头 25页中英文论文及Python代码
本文提供了一篇25页的中英文论文,针对2024美国大学生数学建模竞赛C题"网球运动中的势头",建立了数学模型来分析网球比赛中势头的形成和影响,并通过Python代码实现了模型的定量分析和可视化,同时对模型的合理性、影响因素、预测方法和战术策略进行了深入探讨。
558 3
【2024美赛】C题 Momentum in Tennis网球运动中的势头 25页中英文论文及Python代码
|
人工智能 搜索推荐 机器人
人工智能在电商领域还有哪些应用场景
人工智能在电商领域还有哪些应用场景
780 0
|
机器学习/深度学习 人工智能 监控
深度学习在图像识别中的应用与未来发展
随着科技的不断进步,深度学习已成为人工智能领域的重要技术。本文探讨了深度学习在图像识别中的应用,以及未来可能的发展方向,并提供了一些实际应用案例。
238 27
|
存储 固态存储 安全
云存储性能优化的关键指标
【6月更文挑战第4天】云存储性能优化关乎用户体验与企业效率,关键指标包括:吞吐量(衡量数据处理能力)、IOPS(反映读写操作速度)、延迟(影响用户感知速度)、带宽(数据传输速率)和数据冗余及容错机制(保障数据安全与服务连续性)。优化涉及硬件、软件和网络层面,服务商需不断创新以满足增长的业务需求,为用户提供高效、安全的云存储服务,驱动数字世界发展。
674 5
云存储性能优化的关键指标
|
监控 数据管理 计算机视觉
电脑监控软件中的Icon模式匹配
**Icon模式匹配**是电脑监控软件的关键功能,用于识别界面元素。基本原理是通过图像处理比对预定义图标。示例代码展示了一个Python应用,使用OpenCV库进行模板匹配,找到屏幕上的特定图标并标记其位置。监控软件借此可自动化识别,如浏览器图标,并自动将数据提交至网站,提升数据收集效率和准确性。
221 2
|
人工智能 弹性计算 定位技术
【云故事探索】NO.4: 千寻位置,时空智能赋能行业数字化转型
千寻位置,成立于2015年,利用北斗卫星系统及全球5000多座增强站,提供厘米级定位服务。该公司借助阿里云的计算能力,为汽车、农业等多个行业提供高精度时空智能解决方案,推动行业转型升级。千寻已完成超130亿元估值的A轮融资,展现了其在时空智能领域的领先地位。通过云上部署,千寻优化服务质量和市场扩展,应对突发流量,计划进一步全球化并应用AI技术。阿里云的支持对于千寻的成功至关重要,双方合作将时空智能服务推向国际。
【云故事探索】NO.4: 千寻位置,时空智能赋能行业数字化转型
|
安全 数据处理 量子技术
探索未来互联网:量子计算与区块链技术的融合
本文深入探讨了量子计算和区块链技术的结合如何开启互联网的未来。通过分析量子计算的原理及其对传统加密技术的挑战,以及区块链技术在数据安全和信息共享方面的优势,揭示了两者结合带来的革命性影响。文章还预测了这一技术融合对金融、医疗等行业的潜在变革,并讨论了面临的挑战及未来的发展方向。
|
存储 人工智能 开发者
比GPT-4快18倍,世界最快大模型Groq登场!
【2月更文挑战第2天】比GPT-4快18倍,世界最快大模型Groq登场!
322 3
比GPT-4快18倍,世界最快大模型Groq登场!
|
安全 Python
全局代理IP的工作原理和实现方法
全局代理IP的工作原理和实现方法
362 7