web前端|css教程
CSS,margin
web前端-css教程
php 直播聊天室源码,vscode文件无法打开,ubuntu管道试验,tomcat限制json,sqlite 多大数据量,python爬虫一般分为几步,discuz php代码,綦江区seo优化市价,仿花瓣站网站,网页2147467259错误,dedecms 营销网站模板免费下载lzw
负边距即margin属性的值设为负值,在CSS布局中时一个很有用的技巧。值为正的场景很常见,大家都很熟悉其表现
告白游戏源码,从光盘重装Ubuntu,爬虫出现403错误,php triml,沁阳网站seolzw
当margin-top、margin-left为负值的时候,会把元素上移、左移,同时文档流中的位置也发生相应变化,这点与position:relative的元素设置top、left后元素还占据原来位置不同
基于c语言的指纹识别源码,Ubuntu挂载磁盘密码,爬虫作业豆瓣电影,php sesssion,反代理SEOlzw
当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%处,再对元素设置其自身高度、长度一般的负边距,使元素中心移动到父元素中心,实现居中对齐
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,由于一排放不下,最后一个陪移动到了下一行
我们对代码稍作修改
.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的负边距
这时候发现第三个元素移上去了,并且覆盖了第二个元素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宽度的右边距,覆盖区域没有内容,这样就实现了两列布局
普通元素
负边距对不同块元素的影响很有意思,我们通过几个例子来看一下
多列列表
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设置了水平的负边距后竟然变大了
PS. 效果能实现的前提是元素的宽度不能设置为auto以外的值
带有右边距的浮动子元素列表
看到这种效果你第一想法是什么?会不会是子元素设置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,而是通过负边距使父元素“变大”。
负边距是不是很有意思,不很了解的少年们学起来吧!
编程学习!!