最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to dynamically change Vue.js transition - Stack Overflow

programmeradmin2浏览0评论

I want to dynamically change what kind of animation happens depending on a user's action. So for example, when the first button is clicked and the leave animation is called the "hello" element should use the bounceOutRight animation. However, if the user clicks the second button the "hello" element should use the bounceOutLeft animation. This example es from the vue.js documentation and I am trying to expand on it. As in the vue example it uses the animate.css library.

I tried using v-bind:leave-active-class="animated bounceOutRight" but that threw an error as an invalid expression.

<button @click="show = !show">
  Toggle Bounce Right
</button>
<button @click="show = !show">
  Toggle Bounce Left
</button>
<transition
  name="custom-classes-transition"
  enter-active-class="animated tada"
  leave-active-class="animated bounceOutRight"
>
  <p v-if="show">hello</p>
</transition>

I want to dynamically change what kind of animation happens depending on a user's action. So for example, when the first button is clicked and the leave animation is called the "hello" element should use the bounceOutRight animation. However, if the user clicks the second button the "hello" element should use the bounceOutLeft animation. This example es from the vue.js documentation and I am trying to expand on it. As in the vue example it uses the animate.css library.

I tried using v-bind:leave-active-class="animated bounceOutRight" but that threw an error as an invalid expression.

<button @click="show = !show">
  Toggle Bounce Right
</button>
<button @click="show = !show">
  Toggle Bounce Left
</button>
<transition
  name="custom-classes-transition"
  enter-active-class="animated tada"
  leave-active-class="animated bounceOutRight"
>
  <p v-if="show">hello</p>
</transition>
Share Improve this question edited Jul 13, 2022 at 22:57 tony19 139k23 gold badges277 silver badges347 bronze badges asked Dec 18, 2016 at 16:16 dpstdpst 1,2831 gold badge15 silver badges23 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 9

You can use v-bind for this purpose, you can have name of transition as vue data variable and following will make sure it is dynamic:

<transition
  v-bind:name="className"
  v-bind:enter-active-class="enterClassName"
  v-bind:leave-active-class="leaveClassName"
>

or in short

<transition
  :name="className"
  :enter-active-class="enterClassName"
  :leave-active-class="leaveClassName"
>
发布评论

评论列表(0)

  1. 暂无评论