flex-shrink 不会在 IE 10/11 中缩小项目并导致 parent 比 parent 宽
flex-shrink won't shrink item in IE 10/11 and causes parent to be wider than parent
我的布局由一行三列组成。
左右应与其内容一样宽。其余宽度应由标题列占据。所有列的总宽度不应超过 parent.
所有栏目都应该只有一行内容,没有换行符。
如果标题列的内容不符合约束条件,则应在末尾添加省略号。
所有这些在 Chrome 和 Edge 中都有效,但 IE 拒绝缩小标题列以使列适合其 parent 的宽度。
html,
body {
width: 100%;
margin: 0;
}
.row {
display: -ms-flexbox;
display: flex;
/* https://css-tricks.com/snippets/css/a-guide-to-flexbox/ */
width: 200px;
}
[class*='cell-'] {
-ms-flex: 0 0 auto;
flex: 0 0 auto;
/* https://css-tricks.com/flexbox-truncated-text/ */
min-width: 0;
}
.cell-left {
background: red;
}
.cell-title {
white-space: nowrap;
-ms-flex: 0 1 auto;
flex: 0 1 auto;
}
.hover {
overflow-x: hidden;
text-overflow: ellipsis;
position: relative;
padding-right: 1em;
}
.chevron {
position: absolute;
right: 0;
}
.hover:hover {
background: green;
}
.cell-right {
background: yellow;
margin-left: auto;
}
<div class="row">
<div class="cell-left">Left</div>
<div class="cell-title">
<div class="hover">Pellentesque habitant morbi tristique senectus et netus et malesuada<span class="chevron">^</span></div>
</div>
<div class="cell-right">Right</div>
</div>
IE 10/11 需要在中间项上指定宽度。对您的代码进行此调整
.row {
display: flex;
width: 200px;
}
.cell-title {
width: 100%;
min-width: 0;
display: flex;
}
.hover {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.cell-title::after {
content: '^';
padding-left: 5px;
margin-right: auto;
}
.hover:hover { background: green; }
.cell-left { background: red; }
.cell-right { background: yellow; }
html, body { margin: 0; }
<div class="row">
<div class="cell-left">Left</div>
<div class="cell-title">
<div class="hover">Pellentesque habitant morbi tristique senectus et netus et malesuada</div>
</div>
<div class="cell-right">Right</div>
</div>
我的布局由一行三列组成。
左右应与其内容一样宽。其余宽度应由标题列占据。所有列的总宽度不应超过 parent.
所有栏目都应该只有一行内容,没有换行符。
如果标题列的内容不符合约束条件,则应在末尾添加省略号。
所有这些在 Chrome 和 Edge 中都有效,但 IE 拒绝缩小标题列以使列适合其 parent 的宽度。
html,
body {
width: 100%;
margin: 0;
}
.row {
display: -ms-flexbox;
display: flex;
/* https://css-tricks.com/snippets/css/a-guide-to-flexbox/ */
width: 200px;
}
[class*='cell-'] {
-ms-flex: 0 0 auto;
flex: 0 0 auto;
/* https://css-tricks.com/flexbox-truncated-text/ */
min-width: 0;
}
.cell-left {
background: red;
}
.cell-title {
white-space: nowrap;
-ms-flex: 0 1 auto;
flex: 0 1 auto;
}
.hover {
overflow-x: hidden;
text-overflow: ellipsis;
position: relative;
padding-right: 1em;
}
.chevron {
position: absolute;
right: 0;
}
.hover:hover {
background: green;
}
.cell-right {
background: yellow;
margin-left: auto;
}
<div class="row">
<div class="cell-left">Left</div>
<div class="cell-title">
<div class="hover">Pellentesque habitant morbi tristique senectus et netus et malesuada<span class="chevron">^</span></div>
</div>
<div class="cell-right">Right</div>
</div>
IE 10/11 需要在中间项上指定宽度。对您的代码进行此调整
.row {
display: flex;
width: 200px;
}
.cell-title {
width: 100%;
min-width: 0;
display: flex;
}
.hover {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.cell-title::after {
content: '^';
padding-left: 5px;
margin-right: auto;
}
.hover:hover { background: green; }
.cell-left { background: red; }
.cell-right { background: yellow; }
html, body { margin: 0; }
<div class="row">
<div class="cell-left">Left</div>
<div class="cell-title">
<div class="hover">Pellentesque habitant morbi tristique senectus et netus et malesuada</div>
</div>
<div class="cell-right">Right</div>
</div>