Maison > interface Web > js tutoriel > Vue-router combiné avec la transition pour réaliser le partage d'exemples d'effet de commutation d'animation d'application

Vue-router combiné avec la transition pour réaliser le partage d'exemples d'effet de commutation d'animation d'application

小云云
Libérer: 2018-01-25 10:58:18
original
3215 Les gens l'ont consulté

Cet article vous apporte principalement un exemple de Vue-router combiné avec une transition pour obtenir l'effet de commutation d'animation avant et arrière de l'application. L'éditeur le trouve plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence pour tout le monde. Suivons l'éditeur pour y jeter un œil, j'espère que cela pourra aider tout le monde.

1. Configurez d'abord le routage et modifiez la configuration du routage

La configuration du routage n'est pas le but Ajoutez une méthode goBack à VueRoute pour enregistrer l'état avant et arrière de l'itinéraire.

this.isBack = true VueRouter.prototype.goBack = function () { 
  this.isBack = true
  window.history.go(-1)
}
Copier après la connexion

2. Surveillez les changements d'itinéraire (lorsque l'itinéraire change, déterminez si l'état de l'itinéraire est en avant ou en arrière)

<template>
  <p>

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

    <transition :name="transitionName"> 
      <router-view class="Router"></router-view>
    </transition>
  </p>
</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>
Copier après la connexion

3. Ajoutez différents effets d'animation au animations avant et arrière, le code spécifique est le suivant :

<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>
Copier après la connexion

4. Lorsque l'itinéraire avance, suivez simplement la méthode normale

5. Lorsque l'itinéraire avance ; est en marche arrière, vous pouvez appeler la méthode goBack ;

Recommandations associées :

Comparaison complète des attributs liés à l'animation CSS3 transition, animation, transformation

Analyse d'exemples d'attributs de transition en CSS3

10 articles recommandés sur la transition

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal