[英]Unable to hide flex items by changing width or flex-basis
我想达到这个效果:
在默认状态下,有四个按钮。 其中之一是“移动”按钮。
当用户单击它时,我想展开按钮并显示其他文本和输入。
但是我无法达到“默认状态”。 'To' 总是出现。 我试过flex-basis
和width: 0px
但没有效果,像这样
如何在不使用display:none
情况下隐藏弹性框元素。 不使用display
主要原因是因为我想在宽度上使用一些 css 动画来扩展小部件。
这是 HTML 代码:
<div class="multiselect-controls">
<span class="multiselect-controls-container medium-theme">
<button type="submit" class="btn btn-multi-select multi-edit">
<span class="multiselect-text">Edit</span>
</button>
<button type="submit" class="btn btn-multi-select multi-copy">
<span class="multiselect-text">Copy</span>
</button>
<button type="submit" class="btn btn-multi-select multi-move" onclick="expandMe();">
<span class="multiselect-text">Move</span>
<span class="multi-move-input">
to <input class="multi-move-to-target" type='text'></input>
</span>
</button>
<button type="submit" class="btn btn-multi-select multi-delete">Delete</button>
<span class='icon icon-cross close-multiselect-controls'></span>
</span>
</div>
和css(less)
代码:
btn-multi-select {
display:flex;
width: 100px;
}
.multi-move-input {
flex-basis: 0px;
// overflow: hidden;
flex-grow: 0;
flex-shrink: 1;
}
.expanded {
&.multi-move {
width: 150px;
}
.multi-move-input {
flex-grow: 1;
flex-basis: auto;
}
}
.multi-move-to-target {
width: 30px;
height: 20px;
color: black;
}
Javascript:
function expandMe(event) {
$('.multi-move').toggleClass('expanded');
}
该代码也可在此处获得: http : //codepen.io/kongakong/pen/amdrJZ
如何在不使用
display:none
情况下隐藏弹性框元素? 不使用display
主要原因是因为我想在宽度上使用一些 css 动画来扩展小部件。
您可以使用max-width
,这是一个 可动画的属性。
从0
开始,然后将其扩展为一些额外的大数。 该元素只会扩展到足以容纳内容。
.multi-move-input {
display: inline-flex;
max-width: 0;
transition: .5s;
overflow: hidden;
}
.expanded {
&.multi-move { }
.multi-move-input {
max-width: 200px;
transition: 1s;
}
}
需要考虑的两件事:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.