margintop和marginbottom(margin相对于谁)
【css】外边距margin的属性和使用方法
外边距很好理解,就是指边框以外的距离,可以表示和其它元素之间的距离,使用margin属性来设置。
margin后面可跟多个值,中间用空格分离,含义如下:
(1)首先我们放置三个盒子,颜色不同,宽高均为100px。
(2)我们给中间的橙色盒子加上一个10px的上外边距,可以看到橘黄色的盒子向下移动了10px,上面多了一个上外边距。
(3)接下来我们去掉上外边距,改成给橘黄色盒子加上一个10px的下外边距,发现橘黄色盒子并没有移动,移动的是下面的黄色盒子,所以margin-top和margin-bottom的用法一定要区分开。
(4)外边距可以是赋值,我们给橘黄色盒子添加一个-50px的上外边距,可以看到橘黄色盒子向上移动了。
(1)我们放置一个大的红色盒子,里面包着一个小的橘黄色盒子,当我们为橘黄色盒子添加了一个50px的上外边距的时候,本来应该只是小盒子多了上外边距然后导致向下移动。结果发现,效果就好像是给大盒子加了上外边距一样,大盒子跟着小盒子一起塌陷下去了,并不是我们想要的效果。
(2)如果大盒子有边框,或者橘黄色盒子上面还有元素,情况会是正常的,可以达到我们想要的效果,不会出现塌陷:
(3)解决方法
在外部元素上面没有边框,其内部上方也没有其它元素挡着的时候,给其子元素设置上外边距,会导致塌陷,达不到想要的效果。目前我们只能在遇到这种情况的时候尽量使用padding去设置,不要使用margin,当然还有很多别的解决方法,就不细说啦。
我们放置两个盒子,给上面的盒子添加一个100px的下外边距,给下面的盒子添加一个50px的上外边距,最终效果如图所示,两个盒子最后中间只隔了100px:
当下方元素的上外边距遇到上方元素的下外边距,是会发生重合效果的,设置的时候一定要注意。
块元素才可以设置上下左右外边距,内联元素设置上下外边距是无效的。
margin_top:40px;是什么意思
margin_top:40px。是代表上右下左(按顺时针)边距为40。Margin:包括margin-top,margin-right,margin-bottom,margin-left,控制块级元素之间的距离,它们是透明不可见的,对于Fig.2所示的上右下左margin值均为40px,因此代码为:margin-top:40px。margin-right:40px。margin-bottom:40px。margin-left:40px。根据上,右,下,左的顺时针规则,简写为margin:40px40px40px40px。当上下,左右margin值分别一致,可简写为:margin:40px40px。前一个40px代表上下margin值,后一个40px代表左右margin值.当上下左右margin值均一致,可简写为:margin:40px。
margin属性又细分为哪些属性?
细分为 margin-top、margin-right、margin-bottom、margin-right,
分别表示离上边、右边、下边、左边的距离
margin-top,margin-right,margin-bottom,margin-left具体含义?
就是你的body或者TABLE离上一层的距离。margin_top:0px;放在BODY的样式里就是离浏览器的上边距0px,放TABLE里就是离上一层的上边距为0PX;满意给分。谢谢·!
bottom没有效果,css 设置margin-top或margin-bottom失效不取作用的解决方法
首先来看一个案例:
.bottom-box{
margin -top:30px;
}
我设置了margin-top属性,我的上边距应该距离父元素为30px;
可是结果如何呢?结果并不是class为bottom-box的div上边距离父元素30px;而是距离body元素30px;
什么原因呢?
当个子元素设置margin-top属性时,如何父元素没有设置padding属性,即padding属性为0,那么会出现以上这个情况。
再来看一个实例:
其在IE6和IE7下显示效果为
margin:20px; 只有margin-bottom失效了。
解决办法:只要在浮动的最后一个元素后面加上“
.float_div{float:left; margin:20px; width:100px; height:100px; display:inline; background-color:#CCC;}
.clear{clear:both;}
还有个简单点的解决方法:
IE6/7下margin-bottom无效一般出现在容器里某元素设置后在父容器内无效,这个时候只需要在父容器中加入以下两句css,基本上所有的浏览器都兼容了:
overflow:hidden;zoom:100%;
这个方法不用添加额外的标签,也是很好的解决办法!