您的位置:首页 > 博客中心 > 互联网 >

vue-router 简单实例

时间:2022-05-10 12:27

1. HTML 文件

Hello App!

Go to Foo Go to Bar

2. js 页面

// 0. 如果使用模块化机制编程,导入Vue和VueRouter,要调用 Vue.use(VueRouter)

// 1. 定义 (路由) 组件。
// 可以从其他文件 import 进来
const Foo = { template: ‘
foo
‘ } const Bar = { template: ‘
bar
‘ } // 2. 定义路由 // 每个路由应该映射一个组件。 其中"component" 可以是 // 通过 Vue.extend() 创建的组件构造器, // 或者,只是一个组件配置对象。 // 我们晚点再讨论嵌套路由。 const routes = [ { path: ‘/foo‘, component: Foo }, { path: ‘/bar‘, component: Bar } ] // 3. 创建 router 实例,然后传 `routes` 配置 // 你还可以传别的配置参数, 不过先这么简单着吧。 const router = new VueRouter({ routes // (缩写) 相当于 routes: routes }) // 4. 创建和挂载根实例。 // 记得要通过 router 配置参数注入路由, // 从而让整个应用都有路由功能 const app = new Vue({ router }).$mount(‘#app‘) // 现在,应用已经启动了!

对应的路由匹配成功,将自动设置 class 属性值 .router-link-active

通过注入路由器,我们可以在任何组件内通过 this.$router 访问路由器,也可以通过 this.$route 访问当前路由:

// Home.vue
export default {
  computed: {
    username() {
      // 我们很快就会看到 `params` 是什么
      return this.$route.params.username
    }
  },
  methods: {
    goBack() {
      window.history.length > 1 ? this.$router.go(-1) : this.$router.push(‘/‘)
    }
  }
}

3. 动态路由属性

const router = new VueRouter({
  routes: [
    // 动态路径参数 以冒号开头
    { path: ‘/user/:id‘, component: User }
  ]
})

当匹配到一个路由时,参数值会被 this.$route.params 获取到

可以使用 this.$route.params.id 获取路由中动态传入的参数

const User = {
  template: ‘
User {{ $route.params.id }}
‘ }
模式 匹配路径 $route.params
/user/:username /user/evan { username: ‘evan‘ }
/user/:username/post/:post_id /user/evan/post/123 { username: ‘evan‘, post_id: ‘123‘ }

4. 编程式导航

声明式导航:
编程式导航:router.push(...)

当你点击 时,this.$router.push 这个方法会在内部调用,所以说,点击 等同于调用 router.push(...)

// 字符串
router.push(‘home‘)

// 对象
router.push({ path: ‘home‘ })

// 命名的路由
//可通过路由导航守卫中 to.params.userId 获取 123 
router.push({ name: ‘user‘, params: { userId: ‘123‘ }})

// 带查询参数,变成 /register?plan=private
router.push({ path: ‘register‘, query: { plan: ‘private‘ }})

注意:如果提供了 pathparams 会被忽略

const userId = ‘123‘
router.push({ name: ‘user‘, params: { userId }}) // -> /user/123
router.push({ path: `/user/${userId}` }) // -> /user/123
// 这里的 params 不生效
router.push({ path: ‘/user‘, params: { userId }}) // -> /user

本类排行

今日推荐

热门手游