aru*_*sev 1 javascript css vue.js vuejs2
我有一个垂直项目列表,每个项目都可以删除。我将项目放入过渡组中,并为其创建了简单的不透明性并对其进行转换。删除的元素上的过渡按预期工作,但是,如果我删除未放置在底部的元素,则下面的元素会跳起来并在没有任何过渡的情况下就位。我找不到针对这种行为的方法。我只希望下面的元素平滑地向上滑动。
有什么方法可以通过使用CSS TranssentiPms和Vue的动画钩子来实现这种效果?
这是一个演示:https : //jsfiddle.net/gcp18nq0/
模板:
<div id="app">
<div class="form">
<label for="name">Name</label>
<input type="text" id="name" v-model="name">
<button @click="addPlayer">Add player</button>
</div>
<div class="players">
<transition-group name="player">
<div class="panel" v-for="player in players" :key="player.id">
<h2>
{{ player.name}}
<span class="remove" @click="removePlayer(player.id)">Remove</span>
</h2>
</div>
</transition-group>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
脚本:
data() {
return {
name: "",
players: [
{id: 1, name: 'Player1'},
{id: 2, name: 'Player2'},
{id: 3, name: 'Player3'},
]
}
},
methods: {
addPlayer: function () {
//,,,,
},
removePlayer: function (playerId) {
//...
}
}
});
Run Code Online (Sandbox Code Playgroud)
的CSS
.form {
margin:0 auto;
width:400px;
}
.panel {
width: 400px;
margin: 10px auto;
overflow: hidden;
border: 1px solid;
text-align: center;
}
.remove {
float: right;
cursor: pointer;
text-decoration: underline;
font-size: 12px;
vertical-align: bottom
}
.player-enter,
.player-leave-to
/* .fade-leave-active below version 2.1.8 */
{
opacity: 0;
}
.player-enter {
transform: translateY(30%);
}
.player-leave-to {
transform: translateX(30%);
}
.player-enter-active,
.player-leave-active {
transition: all 1.5s;
}
.player-move {
transition: all 1.5s;
}
Run Code Online (Sandbox Code Playgroud)
我发现的唯一工作方式是通过添加position:absolute处于“ player-leave-active”状态,但是由于元素折叠,因此更改了其垂直位置,这不是理想的效果。我还尝试了更改高度,但是在将高度设置为0之后,下面的元素仍然会跳起来。我确信使用jQuery可以轻松实现这一点,但我相信应该有一种不用js的方法。
先感谢您!
ps这是我的第一篇文章,所以我希望对它的解释足够清楚。
因此,我对您的小提琴进行了一些小调整:https://jsfiddle.net/gcp18nq0/1/希望这就是您想要的。
new Vue({
el: "#app",
data() {
return {
name: "",
players: [{
id: 1,
name: 'Batman'
},
{
id: 2,
name: 'Robin'
},
{
id: 3,
name: 'Superman'
},
{
id: 4,
name: 'Spiderman'
},
]
}
},
methods: {
addPlayer: function() {
const newPlayer = {
id: this.players.length + 1,
name: this.name,
};
this.players.push(newPlayer);
},
deletePlayer: function(playerId) {
let playerToRemove = this.players.find((player) => {
return player.id === playerId;
});
let playerIndex = this.players.indexOf(playerToRemove);
this.players.splice(playerIndex, 1);
}
}
});Run Code Online (Sandbox Code Playgroud)
.form {
margin: 0 auto;
width: 400px;
}
.panel {
width: 400px;
margin: 6px auto;
overflow: hidden;
border: 1px solid;
text-align: center;
transition: all 1s;
display: inline-block;
}
.players {
position: relative;
text-align: center;
}
.remove {
float: right;
cursor: pointer;
text-decoration: underline;
font-size: 12px;
vertical-align: bottom
}
.player-enter,
.player-leave-to {
opacity: 0;
}
.player-enter {
transform: translateY(30%);
}
.player-leave-to {
transform: translateX(300%);
}
.player-leave-active {
position: absolute;
}Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.16/vue.min.js"></script>
<div id="app">
<div class="form">
<label for="name">Name</label>
<input type="text" id="name" v-model="name">
<button @click="addPlayer">Add player</button>
</div>
<div class="players">
<transition-group name="player" tag="div">
<div class="panel" v-for="player in players" :key="player.id">
<h2>
{{ player.name}}
<span class="remove" @click="deletePlayer(player.id)">Remove</span>
</h2>
</div>
</transition-group>
</div>
</div>Run Code Online (Sandbox Code Playgroud)
最重要的变化是一套display: inline-block在.panel类。根据Vue文档
一个重要的注意事项是,这些FLIP过渡不适用于设置为display的元素:inline。或者,您可以使用 display:inline-block或将元素放置在flex上下文中。