vue3url变化页面不变
时间: 2023-08-12 16:36:15 浏览: 127
如果你想在 Vue 3 中更改 URL 而不重新加载页面,你可以使用 Vue Router。Vue Router 是 Vue.js 官方的路由管理库,它可以帮助你实现单页应用程序中的路由控制。
在 Vue Router 中,你可以使用 `<router-link>` 组件创建链接,使用 `<router-view>` 组件显示路由组件。当用户点击链接时,Vue Router 会更新 URL,并使用 JavaScript 动态更新页面内容,而不需要重新加载整个页面。
下面是一个简单的例子,演示如何使用 Vue Router 更改 URL 而不重新加载页面:
1. 安装 Vue Router
使用 npm 安装 Vue Router:
```
npm install vue-router
```
2. 创建路由
在 `src` 目录下创建一个名为 `router.js` 的文件,用于定义路由:
```javascript
import { createRouter, createWebHistory } from 'vue-router'
import Home from './views/Home.vue'
import About from './views/About.vue'
const routes = [
{
path: '/',
name: 'Home',
component: Home
},
{
path: '/about',
name: 'About',
component: About
}
]
const router = createRouter({
history: createWebHistory(),
routes
})
export default router
```
上面的代码定义了两个路由:`/` 和 `/about`,分别对应 `Home` 和 `About` 组件。
3. 注册路由
在 `main.js` 中注册路由:
```javascript
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
const app = createApp(App)
app.use(router)
app.mount('#app')
```
上面的代码使用 `app.use(router)` 注册路由。
4. 创建链接和显示路由组件
在 `App.vue` 中创建链接和显示路由组件:
```vue
<template>
<div id="app">
<nav>
<router-link to="/">Home</router-link>
<router-link to="/about">About</router-link>
</nav>
<router-view />
</div>
</template>
<script>
export default {
name: 'App'
}
</script>
```
上面的代码使用 `<router-link>` 组件创建链接,使用 `<router-view>` 组件显示路由组件。
5. 运行应用程序
现在你可以运行应用程序:
```
npm run serve
```
打开浏览器,访问 `http://localhost:8080`,你应该能看到一个包含两个链接的页面。点击链接,URL 会更新,但页面不会重新加载。
阅读全文