vue实现app页面切换动画效果实例
程序员文章站
2022-06-08 23:19:32
因为需要实现类似app页面切换的动画效果,百度google搜索比较少资料,所以自己写文档,希望对您有用
在router/index.js
import...
因为需要实现类似app页面切换的动画效果,百度google搜索比较少资料,所以自己写文档,希望对您有用
在router/index.js
import vue from 'vue' import router from 'vue-router' vue.use(router) router.prototype.goback = function () { this.isback = true window.history.go(-1) } const router = new router({ routes: [ { path: '/', name: 'pagetransition', component: pagetransition, // 引入页面切换组件 children: [{ path: '', component: index // 父路由访问页面,例如,访问www.aaa.com/ 显示的是index组件 }, { path: '/pagea', component: pagea // 子路由组件 例如,访问www.aaa.com/pagea 显示为pagea }, { path: '/pageb', component: pageb // 子路由组件 例如,访问www.aaa.com/pageb 显示为pageb }] } ] })
监听路由变化
在放置 <router-view>的vue文件中
//templete <transition name='transitionname' keep-alive> <router-view></router-view> </transition> //script beforerouteupdate(to,from,next){ let isback = this.$router.isback; if( isback ){ this.transitionname = 'slide-right' }else{ this.transitionname = 'slide-left' } this.$router.isback = false; } //style .slide-left-enter, .slide-right-leave-active { opacity: 0; -webkit-transform: translate(50px, 0); transform: translate(50px, 0); } .slide-left-leave-active, .slide-right-enter { opacity: 0; -webkit-transform: translate(-50px, 0); transform: translate(-50px, 0); }
在需要点击返回的按钮中设置 goback
<div class="left" @click="goback"><</div> methods: { goback () { this.$router.goback() } }
我自己的github地址 https://github.com/jaction/page-app-ainimate
大牛的github地址https://github.com/zhengguorong/pageainimate
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: laravel邮件发送的实现代码示例