美文网首页
Vue(篇幅三)

Vue(篇幅三)

作者: HW_____T | 来源:发表于2017-09-27 16:01 被阅读0次

    关于如何学习Vue,Vue的缔造者尤雨溪前辈曾经在知乎发表过一篇新手向:Vue 2.0 的建议学习顺序
    关于Vue其他知识介绍:
    篇幅一
    篇幅二
    篇幅四

    6. 过渡 & 动画

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

    • 在 CSS 过渡和动画中自动应用 class
    • 可以配合使用第三方 CSS 动画库,如 Animate.css
    • 在过渡钩子函数中使用 JavaScript 直接操作 DOM
    • 可以配合使用第三方 JavaScript 动画库,如 Velocity.js
      6.1 单元素/组件过渡
      Vue 提供了transition的封装组件。
      CSS过渡:
      在进入/离开的过渡中,会有 6 个 class 切换。
      v-enter:定义进入过渡的开始状态。在元素被插入时生效,在下一个帧移除。
      v-enter-active:定义过渡的状态。在元素整个过渡过程中作用,在元素被插入时生效,在 transition/animation 完成之后移除。这个类可以被用来定义过渡的过程时间,延迟和曲线函数。
      v-enter-to: 2.1.8版及以上 定义进入过渡的结束状态。在元素被插入一帧后生效 (于此同时 v-enter 被删除),在 transition/animation 完成之后移除。
      v-leave: 定义离开过渡的开始状态。在离开过渡被触发时生效,在下一个帧移除。
      v-leave-active:定义过渡的状态。在元素整个过渡过程中作用,在离开过渡被触发后立即生效,在 transition/animation 完成之后移除。这个类可以被用来定义过渡的过程时间,延迟和曲线函数。
      v-leave-to: 2.1.8版及以上 定义离开过渡的结束状态。在离开过渡被触发一帧后生效 (于此同时 v-leave 被删除),在 transition/animation 完成之后移除
      v-是这些类的前缀,为transition 添加name属性可以重置前缀。
      CSS动画:
      CSS动画用法同CSS过渡类似,区别是在在动画中v-enter类型在节点插入后DOM后不会立即删除,而是在animationend事件触发时删除。
      6.2 自定义过渡的类名
      我们可以通过一下特性来定义过渡类名:
    • enter-class
    • enter-active-class
    • enter-to-class(2.1.8+)
    • leave-class
    • leave-active-class
    • leave-to-class(2.1.8+)

    他们的优先级高于普通的类名,这对于 Vue 的过渡系统和其他第三方 CSS 动画库,如 Animate.css 结合使用十分有用。
    示例:

    <link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css">
    
    <div id="example-3">
    <button @click="show = !show">
    Toggle render
    </button>
    <transition
    name="custom-classes-transition"
    enter-active-class="animated tada"
    leave-active-class="animated bounceOutRight"
    >
    <p v-if="show">hello</p>
    </transition>
    </div>
    

    6.3 显性的过渡持续时间
    <transition>组件上的duration属性定制一个显性的过渡持续时间:
    <transition :duration="1000"> </transition>
    <transition :duration="{ enter:500,leave:800}"></transition>
    6.4 JavaScript钩子
    可以在属性中声明 JavaScript 钩子

    <transition
      v-on:before-enter="beforeEnter"
      v-on:enter="enter"
      v-on:after-enter="afterEnter"
      v-on:enter-cancelled="enterCancelled"
      v-on:before-leave="beforeLeave"
      v-on:leave="leave"
      v-on:after-leave="afterLeave"
      v-on:leave-cancelled="leaveCancelled"
    >
      <!-- ... -->
    </transition>
    
    methods: {
      // --------
      // 进入中
      // --------
      beforeEnter: function (el) {
        // ...
      },
      // 此回调函数是可选项的设置
      // 与 CSS 结合时使用
      enter: function (el, done) {
        // ...
        done()
      },
      afterEnter: function (el) {
        // ...
      },
      enterCancelled: function (el) {
        // ...
      },
      // --------
      // 离开时
      // --------
      beforeLeave: function (el) {
        // ...
      },
      // 此回调函数是可选项的设置
      // 与 CSS 结合时使用
      leave: function (el, done) {
        // ...
        done()
      },
      afterLeave: function (el) {
        // ...
      },
      // leaveCancelled 只用于 v-show 中
      leaveCancelled: function (el) {
        // ...
      }
    }
    

    注意:
    当只用 JavaScript 过渡的时候, 在enterleave 中,回调函数 done 是必须的 。否则,它们会被同步调用,过渡会立即完成。

    推荐对于仅使用 JavaScript 过渡的元素添加 v-bind:css="false",Vue 会跳过 CSS 的检测。这也可以避免过渡过程中 CSS 的影响。
    6.4 初始渲染的过渡
    可以通过appear特性设置节点的在出事渲染的过渡
    <transition appear></transition>
    这里默认和进入和离开过渡一样,同样也可以自定义CSS类名。

    <transition
      appear
      appear-class="custom-appear-class"
      appear-to-class="custom-appear-to-class" (2.1.8+)
      appear-active-class="custom-appear-active-class"
    >
      <!-- ... -->
    </transition>
    

    自定义 JavaScript 钩子:

    <transition
      appear
      v-on:before-appear="customBeforeAppearHook"
      v-on:appear="customAppearHook"
      v-on:after-appear="customAfterAppearHook"
      v-on:appear-cancelled="customAppearCancelledHook"
    >
      <!-- ... -->
    </transition>
    

    6.5 多个元素的过渡
    注意:当有相同标签名的元素切换时,需要通过 key 特性设置唯一的值来标记以让 Vue 区分它们,否则 Vue 为了效率只会替换相同标签内部的内容。即使在技术上没有必要,给在 <transition> 组件中的多个元素设置 key 是一个更好的实践。
    6.6 过渡模式
    Vue提供了过渡模式:

    • in-out:新元素先进行过渡,完成之后当前元素过渡离开。
    • out-in:当前元素先进行过渡,完成之后新元素过渡进入。

    相关文章

      网友评论

          本文标题:Vue(篇幅三)

          本文链接:https://www.haomeiwen.com/subject/stduextx.html