Comment vue ne change-t-il pas l'URL

PHPz
Libérer: 2023-04-17 14:03:01
original
1628 Les gens l'ont consulté

Vue.js est actuellement l'un des frameworks JavaScript les plus populaires. Il aide les développeurs à créer rapidement des applications complexes d'une seule page (SPA). Dans Vue.js, le changement de composant entraîne généralement la modification de l'adresse URL. Cependant, dans certains cas, il est nécessaire d'empêcher les modifications d'adresse URL, et cet article explorera quelques méthodes pratiques.

Utilisez la méthode de remplacement de Vue Router au lieu de la méthode push

Vue Router est le gestionnaire de routage officiellement fourni par Vue.js. Il gère la navigation et le routage au sein de l'application. Par défaut, Vue Router utilise la méthode push pour modifier les adresses URL lors de la navigation. Par exemple :

this.$router.push('/new-page')
Copier après la connexion

Si vous devez accéder à une autre page sans modifier l'adresse URL, vous pouvez utiliser la méthode de remplacement. Par exemple :

this.$router.replace('/new-page')
Copier après la connexion

Utilisation de l'API history

HTML5 fournit l'objet window.history, qui peut modifier l'adresse URL sans actualiser la page. Dans Vue.js, nous pouvons utiliser l'API d'historique pour implémenter la navigation dans les pages sans changer l'adresse URL.

Tout d'abord, nous devons utiliser la méthode history.pushState pour ajouter un nouvel état à l'objet historique du navigateur. Par exemple :

history.pushState({}, '', '/new-page')
Copier après la connexion

Cela entraînera le changement de l'adresse URL dans la barre d'adresse du navigateur en /new-page, mais la page ne sera pas rechargée. Ensuite, nous devons mettre à jour les composants de l'application Vue.js afin que le contenu de la nouvelle page soit affiché. Nous pouvons utiliser l'attribut watch de Vue Router pour écouter les changements dans les adresses URL afin de mettre à jour les composants de l'application. Par exemple :

// 在Vue Router的路由配置中
const routes = [
  {
    path: '/new-page',
    component: NewPageComponent
  }
]

// 在Vue.js组件中
export default {
  watch: {
    $route(to, from) {
      // 在这里更新组件内容
    }
  }
}
Copier après la connexion

Enfin, pour garantir que l'utilisateur peut naviguer en arrière et en avant dans l'historique du navigateur, nous devons remplacer l'état actuel de l'application par le nouvel état à l'aide de la méthode history.replaceState. Par exemple :

history.replaceState({}, '', '/new-page')
Copier après la connexion

Utiliser l'adresse de hachage

Dans Vue.js, vous pouvez éviter de modifier l'adresse URL si vous utilisez l'adresse de hachage. L'adresse de hachage fait référence à la partie de l'adresse URL commençant par le caractère #. Lors de l'utilisation d'adresses de hachage, le navigateur ne recharge pas la page mais navigue au sein du client. Par exemple :

this.$router.push('/#new-page')
Copier après la connexion

Dans Vue.js, nous pouvons utiliser l'attribut mode de Vue Router pour configurer le mode de routage. Par exemple :

const router = new VueRouter({
  mode: 'hash',
  routes: [
    {
      path: '/',
      component: HomeComponent
    },
    {
      path: '/new-page',
      component: NewPageComponent
    }
  ]
})
Copier après la connexion

En définissant le mode sur hash, nous pouvons faire en sorte que Vue Router utilise des adresses de hachage au lieu d'adresses URL complètes lors de la navigation.

Résumé :

Dans Vue.js, il est possible d'empêcher les modifications d'adresse URL en utilisant la méthode de remplacement, l'API d'historique et l'adresse de hachage de Vue Router. Si nous devons changer l'adresse URL, nous pouvons utiliser la méthode push ou modifier l'objet window.location. Choisir différentes solutions à mettre en œuvre selon les besoins spécifiques.

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!

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