Попытка построить аккордеонное меню. анимация пунктов под меню плавная, но закрытие и открытие меню не плавное.
Я нашел пару таких примеров https://codepen.io/anon/pen/dgBWjy?editors=0100. но пока не смог решить мою проблему
Вот мой код до сих пор. любая идея о том, как я могу исправить проблему?
<template>
<div class = "accord">
<div v-for = "group in groups">
<a class = "menu_grps" v-on:click = "group.open = !group.open" v-text = "group.name"></a>
<div id = "anim">
<transition name = "slide">
<div v-show = "!group.open">
<div v-for = "item in group.items" v-text = "item"></div>
</div>
</transition>
</div>
</div>
</div>
</template>
<script>
export default {
data() {
return {
groups: {
"group 1": {
name: "Menu 1",
open: "false",
items: ['item1', 'item2']
},
"group 2": {
name: "Menu 2",
open: "false",
items: ['item1', 'item2', 'item3']
},
"group 3": {
name: "Menu 3",
open: "false",
items: ['item1', 'item2', 'item3', 'item4']
}
}
}
}
}
</script>
<style>
.slide-leave-active,
.slide-enter-active {
transition: all .5s ease;
}
.slide-enter,
.slide-leave-to{
opacity: 0;
transform: translateY(-100%);
margin-bottom: -10px;
}
.menu_grps{
background-color: #BFAEAB;
font-size: 18px;
}
#anim {
overflow: hidden;
}
.accord{
display: flex;
flex-direction: column;
}
</style>





Если вы измените значение поля margin-bottom на -100px, как показано ниже, оно станет намного более плавным:
.slide-enter,
.slide-leave-to{
opacity: 0;
transform: translateY(-100%);
margin-bottom: -100px;
}
Здесь можно найти хороший подход по теме: https://markus.oberlehner.net/blog/transition-to-height-auto-with-vue/. Не добавляйте поля или отступы к анимируемому элементу, лучше добавить их к его дочернему элементу.