美文网首页
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(篇幅三)

    关于如何学习Vue,Vue的缔造者尤雨溪前辈曾经在知乎发表过一篇新手向:Vue 2.0 的建议学习顺序。关于Vue...

  • Vue(篇幅一)

    关于如何学习Vue,Vue的缔造者尤雨溪前辈曾经在知乎发表过一篇新手向:Vue 2.0 的建议学习顺序。笔者推荐使...

  • Vue(篇幅四)

    关于如何学习Vue,Vue的缔造者尤雨溪前辈曾经在知乎发表过一篇新手向:Vue 2.0 的建议学习顺序。关于Vue...

  • Vue(篇幅二)

    关于如何学习Vue,Vue的缔造者尤雨溪前辈曾经在知乎发表过一篇新手向:Vue 2.0 的建议学习顺序。关于Vue...

  • Vue 2.0的项目扩展

    目录 Vue 2.0项目扩展篇主要是讲,Atom插件、Vue依赖库和Vue项目调试,原本是比较长的篇幅,但考虑到每...

  • Cesium开发实战开篇—vite+cesium框架搭建

    在Cesium开发基础篇幅中,我们聊过利用Vue cli搭建Vue2.x+Vesium的框架,但这种方式需要在vu...

  • vue-router原理到最佳实践

    本文是vue-router系列。这里从浏览器到vue-router原理到最佳实践都会有详细的讲解。由于篇幅较长,建...

  • 写作篇幅

    尤其是一些需要长篇幅软文才能论述清楚的问题,从何着手? 1.系列成篇 可以添加小标题、分割线等方式 可以把长篇幅的...

  • 用js实现offset方法

    本来前段时间在整理关于vue组件封装、bind实现、promise实现的文章。但是由于篇幅有点大,并且笔记有些久远...

  • 离线环境安装docker,k8s,prometheus-oper

    篇幅三. docker私有仓库安装 前提: 1.1.1.1 已安装docker,步骤可参照 篇幅二 1.镜像下载 ...

网友评论

      本文标题:Vue(篇幅三)

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