是否有一种方法可以让父容器DIV中的子DIV比父容器DIV宽。子DIV需要与浏览器视口的宽度相同。

请看下面的例子:

子DIV必须作为父DIV的子DIV。我知道我可以在子DIV上设置任意的负边距,使其更宽,但我不知道如何从本质上使它100%的浏览器宽度。

我知道我能做到:

.child-div{
    margin-left: -100px;
    margin-right: -100px;
}

但我需要子节点的宽度与浏览器的宽度相同,浏览器是动态的。

更新

感谢您的回答,到目前为止,似乎最接近的答案是使子DIV位置:绝对,并将左右属性设置为0。

下一个问题是,我有父位置:相对,这意味着左右属性仍然是相对于父div,而不是浏览器,见示例这里:jsfiddle.net/v2Tja/2

我不能从父对象中删除position: relative而不搞砸其他所有东西。


当前回答

你可以试试position: absolute。然后给出宽度和高度,top: 'y轴从顶部开始' 左:x轴

其他回答

我也遇到过类似的问题。 子元素的内容应该保留在父元素中,而背景必须扩展整个视口宽度。

我通过使子元素position: relative和添加一个伪元素(:before)到它的position: absolute来解决这个问题;上图:0;底部:0;宽度:4000 px;左:-1000 px;。 伪元素作为伪背景元素留在实际的子元素后面。这适用于所有浏览器(即使是IE8+和Safari 6+ -也不能测试旧版本)。

小例子:http://jsfiddle.net/vccv39j9/

那么解决方案将如下。

HTML

<div class="parent">
    <div class="child"></div>
</div>

CSS

.parent{
        width: 960px;
        margin: auto;
        height: 100vh
    }
    .child{
        position: absolute;
        width: 100vw
    }
.parent {
    margin:0 auto;
    width:700px;
    border:2px solid red;
}
.child {
    position:absolute;
    width:100%;
    border:2px solid blue;
    left:0;
    top:200px;
}

我知道这是一个古老的问题,但对于任何想要得到答案的人来说,你会这样做:

隐藏在包含父元素(如体)的元素上的溢出。

给你的子元素一个比你的页面宽得多的宽度,并将它放置在绝对左侧-100%。

这里有一个例子:

body {
  overflow:hidden;
}

.parent{
  width: 960px;
  background-color: red;
  margin: 0 auto;
  position: relative;    
}

.child {
  height: 200px;
  position: absolute;
  left: -100%;
  width:9999999px;
}

这里还有一个JS小提琴:http://jsfiddle.net/v2Tja/288/

添加到Nils Kaspersson的解决方案,我正在解决垂直滚动条的宽度。我以16px为例,从视图宽度中减去16px。这将避免出现水平滚动条。

width: calc(100vw - 16px);
left: calc(-1 * (((100vw - 16px) - 100%) / 2));