欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue实现app页面切换动画效果实例

程序员文章站 2023-10-31 14:33:34
因为需要实现类似app页面切换的动画效果,百度google搜索比较少资料,所以自己写文档,希望对您有用 在router/index.js import...

因为需要实现类似app页面切换的动画效果,百度google搜索比较少资料,所以自己写文档,希望对您有用

vue实现app页面切换动画效果实例

在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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。