Vue路由进阶--VueRouter声明式导航

Vue路由进阶--VueRouter声明式导航

文章目录

1、声明式导航

1.1、导航链接

需求:实现导航高亮效果

vue-router提供了一个全局组件router-link(取代a标签)

  1. 跳转,配置 to属性指定路径(必须)。本质还是a标签,to无需#
  2. 高亮,默认就会提供高亮类名,可以直接设置高亮样式

将a标签的代码进行替换:

审查元素将新增的类改变属性:(router-link-exact-active 和 router-link-active)

1.2、高亮类名

说明:我们发现router-link自动给当前导航添加了两个高亮类名(router-link-exact-active 和 router-link-active)

  1. router-link-ctive模糊匹配(用的多)

    复制代码
    to="/my"  => 可以匹配'/my'开头的所有路径,如/my,/my/a/...
  2. router-link-exact-active精确匹配

    复制代码
    to="/my"  =>  仅可以匹配/my

说明:router-link的两个高亮类名太长了,我们希望能定制怎么办?

javascript 复制代码
const router = new VueRouter({
  routes: [...],
  linkActiveclass: "类名1",
  linkExactActiveclass: "类名2"
})

上述操作相当于实现了自定义的类名,将两个高亮的类名进行自定义以达到简写或其他目的。

1.3、跳转传参

在跳转路由时,进行传值,有一下两种方式:

  1. 查询 参数传参
    1. 语法格式如下
      • to="/path?参数名=值"
    2. 对应页面组件接收 传递过来的值
      • $route.query.参数名

参数传递:

vue 复制代码
  <div class="hot-link">
      热门搜索:
      <router-link to="/search?key=程序员">程序员</router-link>
      <router-link to="/search?key=前端培训">前端培训</router-link>
      <router-link to="/search?key=如何成为前端大牛">如何成为前端大牛</router-link>
  </div>

参数接收:

vue 复制代码
<template>
	<div>
        <p>搜索关键字: {{ $route.query.key }} </p>
    </div>
</template>

使用传递过来的值:

vue 复制代码
<template>
	<div>
        <p>搜索关键字: {{ $route.query.key }} </p>
    </div>
</template>
<script>
export default {
  created () {
    // 在created中,获取路由参数:
    // this.$route.query.参数名
    console.log(this.$route.query.key);//拿到值之后就发请求,然后渲染到页面
  }
}
</script>
  1. 动态路由传参

    1. 配置动态路由

      javascript 复制代码
      const router = new VueRouter({
        routes: [
          { path: '/search/:参数名', component: Search }
        ]
      })
    2. 配置导航链接

      • to="/path/参数值"
    3. 对应页面组件接收传递过来的值

      • $route.params.参数名

参数传递:

vue 复制代码
    <div class="hot-link">
      热门搜索:
      <router-link to="/search/程序员">程序员</router-link>
      <router-link to="/search/前端培训">前端培训</router-link>
      <router-link to="/search/如何成为前端大牛">如何成为前端大牛</router-link>
    </div>

参数接受:

vue 复制代码
<template>
	<div>
    	<p>搜索关键字: {{ $route.params.words }} </p>
    </div>
</template>

使用传递过来的参数:

vue 复制代码
<script>
export default {
  name: 'MyFriend',
  created () {
    // 在created中,获取路由参数
    // this.$route.query.参数名 获取查询参数
    // this.$route.params.参数名 获取动态路由参数
    console.log(this.$route.params.words);
  }
}
</script>

两种传参方式哪种要好一些:

  1. 查询参数传参((比较适合传多个参数)
  2. 动态路由传参(优雅简洁,传单个参数比较方便)

1.4、动态路由参数可选符

问题:配了路由path: "/search/:words"为什么按下面步骤操作,路径上没有参数,会未匹配到组件,显示空白?

原因:/search/:words表示,必须要传参数。如果不传参数,也希望匹配,可以加个可选符"?"

解决:

javascript 复制代码
const router = new VueRouter({
  routes: [
    { path: '/home', component: Home },
    { path: '/search/:words?', component: Search }
  ]
})
相关推荐
Ratten3 分钟前
解决 error when starting dev server TypeError crypto$2.getRandomValues
前端
coding随想6 分钟前
深入浅出DOM3合成事件(Composition Events):如何处理输入法编辑器(IME)的复杂输入流程
前端
六月的雨在掘金6 分钟前
狼人杀法官版,EdgeOne 带你轻松上手狼人杀
前端·后端
Ratten11 分钟前
【npm 解决】---- TypeError: crypto.hash is not a function
前端
前端小大白11 分钟前
JavaScript 循环三巨头:for vs forEach vs map 终极指南
前端·javascript·面试
晴空雨13 分钟前
面试题:如何判断一个对象是否为可迭代对象?
前端·javascript·面试
嘻嘻__14 分钟前
掘金沸点屏蔽脚本分享
前端·掘金社区
用户479492835691515 分钟前
🎨 Prettier 深度解析:从历史演进到内部格式化引擎的完整拆解
前端
Man15 分钟前
uniapp中使用unocss适配多端
前端·css
阿虎儿16 分钟前
React 事件类型完全指南:深入理解合成事件系统
前端·javascript·react.js