您的位置:首页 > 移动开发

Vue-router结合transition实现app前进后退动画切换效果

2017-10-10 17:42 1191 查看
一丶首先配置路由并且修改路由配置
路由配置就不讲了
重点,给VueRoute添加一个goBack方法,用于记录路由的前进后退状态 this.isBack = true 


VueRouter.prototype.goBack = function () { 

  this.isBack = true

  window.history.go(-1)

}
 
[/code]


二丶监听路由变化(在路由变化时判断此时的路由状态是前进还是后退)

<template>

  <div>

    动态绑定路由动画,根据路由状态的不同绑定不同的路由动画分别为  :‘slide-left’  和 'slide-right'

    <transition :name="transitionName"> 

      <router-view class="Router"></router-view>

    </transition>

  </div>

</template>

<script>

export default {

  data() {

    return {

      transitionName: 'slide-right'  // 默认动态路由变化为slide-right

    }

  },
  watch: {
   '$route' (to, from) {
    let isBack = this.$router.isBack  //  监听路由变化时的状态为前进还是后退
      if(isBack) {
        this.transitionName = 'slide-right'
      } else {
             this.transitionName = 'slide-left'
     }
  this.$router.isBack = false
  }
   }

 }

</script>


三丶给前进后退动画添加不同的动画效果,具体代码如下:

<style>

.Router {

     position: absolute;

     width: 100%;

     transition: all .8s ease;

     top: 40px;

}

.slide-left-enter,

 .slide-right-leave-active {

     opacity: 0;

    -webkit-transform: translate(100%, 0);

    transform: translate(100%, 0);

}

.slide-left-leave-active,

.slide-right-enter {

     opacity: 0;

    -webkit-transform: translate(-100%, 0);

    transform: translate(-100% 0);

}

</style>

 


四丶路由前进的时候按正常方法走就行了;


五丶后退的时候调用goBack方法就OK;

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: