vue-router使用详解

安装

yarn add vue-router

使用

HTML:

// App.vue

<script src="https://unpkg.com/vue@3"></script>
<script src="https://unpkg.com/vue-router@4"></script>

<div id="app">
  <h1>Hello App!</h1>
  <p>
    <!--使用 router-link 组件进行导航 -->
    <!--通过传递 `to` 来指定链接 -->
    <!--`<router-link>` 将呈现一个带有正确 `href` 属性的 `<a>` 标签-->
    <router-link to="/">Go to Home</router-link>
    <router-link to="/about">Go to About</router-link>
    
  </p>
  <!-- 路由出口 -->
  <!-- 路由匹配到的组件将渲染在这里 -->
  <router-view></router-view>
</div>

自定义路由组件:

// /components/UserPost.vue

<template>
    <div>User {
   {
   this.$route.params}} with post {
   {
   this.$route.postId}}</div>
</template>

JavaScript:

// main.js

// 从vue-router引入createRouter和createWebHashHistory. 如果不引入的话,
// 使用VueRouter.createRouter()来使用
import {
   createRouter, createWebHashHistory} from 'vue-router'

// 1. 定义路由组件.
// 也可以从其他文件导入
// (1)直接定义路由组件
const Home = {
    template: '<div>Home</div>' }
const About = {
    template: '<div>About</div>' }
// (2)从其他组件导入
import UserPost from "./components/UserPost" //(/components/下有一个名为UserPost.vue文件)

// 2. 定义一些路由
// 每个路由都需要映射到一个组件。
// 我们后面再讨论嵌套路由。
const routes = [
  {
    path: '/', component: Home },
  {
    path: '/about', component: About },
  {
    path: '/users/:username/posts/:postId', component: UserPost } // 此路由匹配 http://example.com/users/Jack/posts/123
]

// 3. 创建路由实例并传递 `routes` 配置
// 你可以在这里输入更多的配置,但我们在这里
// 暂时保持简单
const router = createRouter({
   
  // 4. 内部提供了 history 模式的实现。为了简单起见,我们在这里使用 hash 模式。
	history: createWebHashHistory(),
  routes, // `routes: routes`的缩写
})


// 5. 创建并挂载根实例
const app = Vue.createApp({
   })
//确保 _use_ 路由实例使
//整个应用支持路由。
app.use(router) // 此时,可以在任意组件中使用this.$router访问路由对象,并以this.$route的形式访问当前路由

app.mount('#app
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue Router 是 Vue.js 的官方路由管理器,它与 Vue.js 紧密集成,可以让我们轻松地构建单页面应用(SPA)。 在使用 Vue Router 构建单页面应用时,我们通常会使用 `<router-view>` 组件来展示当前路由所对应的组件内容。下面是对 `<router-view>` 组件的使用详解: 1. 定义路由: 在 Vue Router 中,我们需要首先定义路由。可以通过在 `routes` 配置项中定义一个数组来实现,每个路由对象都包含了一个路径和对应的组件。例如: ```javascript import Home from './components/Home.vue' import About from './components/About.vue' const routes = [ { path: '/', component: Home }, { path: '/about', component: About } ] ``` 2. 注册路由: 在创建 Vue 实例之前,我们需要将路由配置注册到 Vue 实例中。可以使用 `Vue.use()` 方法来注册 Vue Router 插件。例如: ```javascript import Vue from 'vue' import VueRouter from 'vue-router' Vue.use(VueRouter) ``` 3. 创建路由实例: 在注册完插件后,我们可以创建一个路由实例,并将之前定义的路由配置传入。例如: ```javascript const router = new VueRouter({ routes }) ``` 4. 添加路由占位符: 在应用的根组件中,我们需要添加一个 `<router-view>` 组件作为路由占位符。这样,当路由切换时,对应的组件就会渲染在这个占位符中。例如: ```html <template> <div> <router-view></router-view> </div> </template> ``` 注意,`<router-view>` 组件可以放置在任何位置,根据实际需求进行布局。 5. 挂载路由: 最后一步是将路由实例挂载到 Vue 实例上。例如: ```javascript new Vue({ router }).$mount('#app') ``` 至此,我们就完成了 `<router-view>` 组件的使用。当用户访问不同的路由时,对应的组件就会被渲染到 `<router-view>` 中,实现了页面的切换效果。 需要注意的是,`<router-view>` 组件只能用于展示路由对应的组件内容,并不能直接显示其他内容。如果需要在路由切换时显示一些其他元素,可以结合使用 `<router-link>` 组件来实现。 希望以上解答对你有帮助!如有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值