我在width
和max-width
之間存在一個問題,該元素在具有祖父母柔性定位容器的元素中工作。寬度(以像素爲單位)忽略最大寬度:100%
當我在這個元素中使用width
的像素與max-width: 100%
,如果寬度大於它的父項,它只是忽略max-width:100%
。但是,如果例如我使用width: 150%
,那麼max-width:100%
就起作用了。
body{
width: 640px;
height: 360px;
position: relative;
}
body:before{
content:"";
width:100%;
height:100%;
box-sizing: border-box;
position: absolute;
border: 2px solid black;
}
body:after{
content:"16:9 screen size ratio example";
position: absolute;
bottom: 0;
right: 10px;
}
#flex-container{
width: 100%;
height: 100%;
display: flex;
flex-flow: row nowrap;
background-color: #95a5a6;
}
#sidebar{
min-width:150px;
flex: 0 1 150px;
background-color: #7f8c8d;
}
#main-content{
width:100%;
flex: 1 1 auto;
background-color: white;
}
.page{
width: 100%;
padding: 16px;
box-sizing: border-box;
}
.grid{
width: 800px;
max-width: 100%;
height: 200px;
background-color: red;
color: white;
padding: 16px;
box-sizing: border-box;
}
<div id="flex-container">
<div id="sidebar"><h2>Sidebar</h2></div>
<div id="main-content">
<div class="page">
<h1>Content page</h1>
<div class="grid">
A grid with certain width defined in units and based on the device. Specified width should not exceed its parent width (max-width: 100%).
</div>
</div>
</div>
</div>
<br><br><br>
Should work like this:
<br>
<div style="width:640px;height:360px; border: 2px solid black;background-color:white;">
<div style="width:100%;height:100%;">
640px width parent
<div style="max-width:100%; width:800px; height:100px; background-color:green;color:white;">
800px width with max-width:100%
</div>
</div>
</div>
這裏是JSFiddle。
最大寬度總是跳動寬度。不確定你的問題是什麼。 –
@Paulie_D應該。這裏是問題,在我的例子中'max-width'沒有超過'width'。看看jsfiddle。 –