我们写了这么多的CSS,也多少了解了margin的一些特性,比如: 不过这里我们要说的当前元素的margin与其父级元素之间产生的效果。 我们以这个DOM结构来举例,.container为最外层的父级元素: 我们先看下上边距的情况,在 .user, .a1, .b1中,无论哪个元素,只要其父级元素没有设置padding-top或者没有其他元素(元素节点或者文本)的输出,那么当前元素的顶部会与其父级元素的顶部对齐,margin-top的边距就会上升到其父级;然后一直向上寻找,直到body元素。 比如上面的结构中,我们给.b1一个margin-top值,最终会上边距会给到了.container 如果我们只想给当前元素一个人margin-top值,并不想影响其父级元素怎么办呢? 再一个就是下边距的问题,下边距会与上边距产生一模一样的问题,也可以按照这3种方式来解决。不过这里的下边距还有另外一个问题。 我们使用这条语句,将.container的最小高度设置为页面的高度: 我们再给.user或.a1或.b1一个margin-bottom值,我们会发现,在.user的高度+下边距还远远没有超过.container的高度时,页面就已经产生滚动条了,说明 这个怎么解决呢,解决方法依然同上!
<style>*{margin: 0; padding: 0;}
.container{background-color: #d8bea5;}
.user{background: #8bce92;}
.user .b1{margin-top: 20px;}style>
<div class="container">
<div class="user">
<div class="a1">
<div class="b1">123div>
div>
div>
div>
visibility:hidden
占位隐藏,但不能用display:none
隐藏,因为dispplay:none
会使这个元素的高度变为0;function resize(){
document.querySelector('.container').style.minHeight= document.documentElement.clientHeight + "px";
}
resize();
margin-bottom
已经作用到.container了。之前没注意到这个现象,是我们的产品在用之前的页面修改后作为新页面的时候,发现产生了滚动条,调试后才发现,原来是里面的一个元素有margin-bottom把整个页面撑开了,造成页面产生了滚动条,底部有一部分的白底。
版权属于:
加速器之家
作品采用:
《
署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)
》许可协议授权
评论