VUE路由转场特效,WebAPP的前进与后退
2019-02-17 01:50:33来源:博客园 阅读 ()
一、效果图

二、思路
1. 定义两个 CSS 过度动画,前进与后退: slide-right-enter 和 slide-left-enter
2. 给路由配置meta信息,设置各个路由的级别: index
3. 监控路由跳转,比对 meta 信息级别,如果从大跳转到小说明是返回,从小跳转到大则是前进
三、具体代码
APP.vue
<template>
<div id="app">
<transition :name="transitionName">
<router-view/>
</transition>
</div>
</template>
<script>
export default {
name: 'app',
data () {
return {
transitionName: ''
}
},
watch: {
$route (to, from) {
if (to.meta.index > from.meta.index) {
this.transitionName = 'slide-left'
} else {
this.transitionName = 'slide-right'
}
}
}
}
</script>
<style lang="scss">
#app {
color: #2c3e50;
}
//转场动画
.slide-right-enter-active,
.slide-right-leave-active,
.slide-left-enter-active,
.slide-left-leave-active {
// 启用硬件加速
will-change: transform;
transition: all 300ms;
position: fixed;
}
.slide-right-enter {
transform: translate(-100%, 0);
transition-timing-function: ease-in;
}
.slide-left-enter {
transform: translate(100%, 0);
transition-timing-function: ease-in;
}
</style>
router.js
import Vue from 'vue' import Router from 'vue-router' import Home from './views/Home.vue' Vue.use(Router) export default new Router({ // mode: 'history', base: process.env.BASE_URL, routes: [ { path: '/', name: 'home', component: Home, meta: { index: 1 } }, { path: '/publish', name: 'publish', component: () => import('./views/Publish.vue'), meta: { index: 2 } }, { path: '/personal', name: 'personal', component: () => import('./views/Personal.vue'), meta: { index: 2 } } ] })
原文链接:https://www.cnblogs.com/similar/p/10329667.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:前端基础之BOM和DOM
- vue.js开发环境搭建教程 2020-03-16
- Vue input控件通过value绑定动态属性及修饰符的方法 2020-03-05
- 详解Webstorm 新建.vue文件支持高亮vue语法和es6语法 2020-02-07
- vue路由跳转时判断用户是否登录功能的实现 2020-01-17
- vue-cli中打包图片路径错误的解决方法 2020-01-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash
