Comportement du défilement

En utilisant le routage côté client, nous pourrions vouloir faire défiler la page jusqu'en haut lorsqu'on navigue vers une nouvelle route, ou alors préserver la position du défilement des entrées de l'historique comme le ferait une page réelle. vue-router vous permet de faire cela et, encore mieux, vous permet de changer le comportement du défilement pendant la navigation.

Note : cette fonctionnalité ne fonctionne que si le navigateur supporte history.pushState.

Pendant la création de l'instance du routeur, vous pouvez renseigner la fonction scrollBehavior :

const router = new VueRouter({
  routes: [...],
  scrollBehavior (to, from, savedPosition) {
    // retourner la position désirée
  }
})

La fonction scrollBehavior reçoit les objets de route to et from. Le troisième argument, savedPosition, est disponible uniquement si c'est une navigation popstate (déclenchée par les boutons précédent/suivant du navigateur).

La fonction peut retourner un objet décrivant la position du défilement. L'objet peut être de la forme :

  • { x: number, y: number }
  • { selector: string, offset? : { x: number, y: number }} (offset seulement supporté pour les versions 2.6.0+)

Si une valeur équivalente à false ou un objet vide est retourné, aucun défilement ne sera produit.

Par exemple :

scrollBehavior (to, from, savedPosition) {
  return { x: 0, y: 0 }
}

Cela permettra de défiler au haut de page à chaque navigation à travers les routes.

Retourner l'objet savedPosition résultera en un comportement quasi natif en naviguant avec les boutons précédents/suivants :

scrollBehavior (to, from, savedPosition) {
  if (savedPosition) {
    return savedPosition
  } else {
    return { x: 0, y: 0 }
  }
}

Si vous voulez simuler le comportement « aller à l'ancre » :

scrollBehavior (to, from, savedPosition) {
  if (to.hash) {
    return {
      selector: to.hash
      // , offset: { x: 0, y: 10 }
    }
  }
}

On peut aussi utiliser les champs meta de route pour implémenter un contrôle bien précis pour le comportement du défilement. Allez voir un exemple complet ici.

Défilement asynchrone

Nouveau dans la 2.8.0+

Vous pouvez également retourner une promesse pour résoudre la description de position souhaitée :

scrollBehavior (to, from, savedPosition) {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve({ x: 0, y: 0 })
    }, 500)
  })
}

Il est possible de relier les événements d'un composant de transition au niveau de la page pour que le comportement de défilement soit bien adapté à vos transitions de pages. Cependant, en raison de la variance et de la complexité des cas d'utilisation, nous fournissons simplement ce code primitif pour permettre aux utilisateurs de faire les implémentations spécifiques.