VUEclass 切换

135 阅读1分钟

定义过渡的状态:

v-enter:定义进入过渡的开始状态。

v-enter-active:定义进入过渡生效时的状态。

v-enter-to:2.1.8 版及以上定义进入过渡的结束状态。

v-leave:定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。

v-leave-active:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。

v-leave-to:2.1.8 版及以上定义离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时 v-leave 被删除),在过渡/动画完成之后移除。

Vue 在插入、更新或者移除 DOM 时,提供多种不同方式的应用过渡效果。 包括以下工具:

在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS 动画库,如 Animate.css 在过渡钩子函数中使用 JavaScript 直接操作 DOM 可以配合使用第三方 JavaScript 动画库,如 Velocity.js

单元素/组件的过渡

Vue 提供了 transition 的封装组件,在下列情形中,可以给任何元素和组件添加进入/离开过渡

  • 条件渲染 (使用 v-if)
  • 条件展示 (使用 v-show)
  • 动态组件
  • 组件根节点

例:

<body>
<div id="app">
    <input type="button" value="切换1" @click="flag=!flag">
    <transition>
        <h3 v-if="flag">这是一个标签</h3>
    </transition>
    <hr>
    <input type="button" value="切换2" @click="flag2 =! flag2">
    <transition name="my">
        <h3 v-if="flag2">这是一个标签</h3>
    </transition>
</div>
    <script src="./js/vue.js"></script>
     <script>
        var vm = new Vue({
            el:"#app",
            data: {
            flag:false,
                flag2:false
            },
            methods:{
            }
        })
    </script>
</body>

样式

<style>
        .v-enter,
        .v-leave-to{
            opacity: 0;
            transform: translateX(150px);
        }
        .v-enter-active,
        .v-leave-avtive{
            transition: all 0.8s ease;
        }
        .my-enter,
        .my-leave-to{
            opacity: 0;
            transform: translateY(150px);
        }
        .my-enter-active,
        .my-leave-avtive{
            transition: all 0.8s ease;
        }
    </style>

点击切换:

image.png 当再次点击:

image.png