Vue-Router路由框架

使用到Vue的项目,我们最常见使用的就是Vue配套的Vue Router库。
Vue-Router是Vue.js的官方路由

创建路由项目( 创建vue-cli2项目,带vue-router)

电脑终端vue ui
选择项目路径,创建项目(项目名称只能小写字母,不能大写)
选择手动配置
截屏2023-05-19 17.05.59.png

I97bKaTU3F.jpg

可以不预设(如果预设了,会把这个项目当作模版,下次再创建时可以选择这个模版创建项目)
截屏2023-05-19 17.10.17.png

打开项目,可以直接运行
nom run serve

安装三方:
vue add axios (如果报错,设置vue.config.js的lintOnSave:false)
vue add element-ui

vue.config.js

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  lintOnSave:false,   //编辑器强检查
  transpileDependencies: true,
  productionSourceMap:false,   //暴露源代码
  outputDir:'betatest'   //打出的包的名称
})

#创建路由项目会自带路由配置代码

  1. router的index.js:路由配置文件
import Vue from 'vue'
import VueRouter from 'vue-router'
import HomeView from '../views/HomeView.vue'
Vue.use(VueRouter)

const routes = [
{
    path: '/home',
    name: 'home',
    component: HomeView  //导入文件路径,跳转会快些
  },
{
    path: '/about',
    name: 'about',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "about" */ '../views/AboutView.vue')  //  这种写法是懒加载,跳转会慢些, ../是指相对当前文件的上一层目录(即:src)
  },
 {
    path: '/HelloWorld',
    name: 'HelloWorld',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "about" */ '@/components/HelloWorld.vue')  //  @/是指src的绝对路径
  }
{
            path: "/",
            redirect: "find" //默认显示推荐组件(路由的重定向)
        },
      
        {
            path: "/find",
            name: "Find",
            component: Find,
            //二级路由
            children: [{
                    path: "/",
                    redirect: "recom" //默认显示推荐组件
                },
                {
                    path: "ranking", //注意二级路由的路径千万不要加/
                    component: Ranking
                },
            ]
        },
        {
            path: "/my",
            name: "My",
            component: My
        },
       
        {
            path: "*",
            component: NotFound //定义找不到已有组件时显示404
        },
    ]

//用规则生成路由对象
    // 创建路由对象并且传入规则
const router = new VueRouter({
    routes,
    mode: "history" //路由模式(默认为hash模式)
})
  1. 挂载路由
    main.js
import router from "./router";

//把路由对象注入到new Vue实例中
new Vue({
    router, //导入路由对象
    render: h => h(App),
}).$mount('#app')

//用router-view作为挂载点, 切换不同的路由页面

3.使用路由
例如:
app.vue:

<template>
  <div id="app">
    <nav>
<!--       router-link: 路由跳转标签-->
      <router-link to="/">Home</router-link> |
      <router-link to="/about">About</router-link>
    </nav>
    
<!--     <router-view/>: 路由占位,等同于<router-view></router-view>-->
    <router-view/>

  </div>
</template>

路由跳转:
this.$router.push(‘/find’)

#Vue-Router跳转方法
参考:https://blog.csdn.net/xiao_yu_liu/article/details/125003546
https://blog.csdn.net/sebeefe/article/details/126080415

1法、使用router-link
使用router-link标签,我们通常会使用到2个参数,最常用的就是to参数
to参数,表示你想要跳转到的路由对象
router-link标签,会调用router.push()方法,该方法会在你点击浏览器会退按钮的时候,无痕回退一个路由。

可以是路由路径
Home
Home

也可以是路由对象,甚至还可以为其携带参数
Home
User

Register

router-link好处 : 自带激活时的类名, 可以做高亮

在跳转路由时, 可以给路由对应的组件内传值
在router-link上的to属性传值, 语法格式如下 :
(方式一)
to=/path参数名=值
例:to=“/part?name=小明”
对应页面组件接收传递过来的值
this. r o u t e . q u e r y . 参数名接收参数数据: t h i s . route.query.参数名 接收参数数据:this. route.query.参数名接收参数数据:this.route.query.name

(方式二)
to=“/path/值” (需在路由规则里配置/path/:参数名)
例:to=“/part/小王”
配置:path:“/part/:username”
对应页面组件接收传递过来的值 (注意动态参数需要用params接收)
this. r o u t e . p a r a m s . 参数名接收参数数据: t h i s . route.params.参数名 接收参数数据:this. route.params.参数名接收参数数据:this.route.params.username

2法、使用router-replace
设置 replace 属性的话,当点击时,会调用 router.replace(),而不是 router.push(),所以导航后不会留下历史记录。

方法1和2是使用html的方法来调用

3法、编程式-用JS代码来进行跳转
语法: path或者name任选一个, 传参query或者params
一、$ router 和 $ route的区别
$router : 是路由操作对象,只写对象
$route : 路由信息对象,只读对象

r o u t e r 操作路由跳转 t h i s . router操作路由跳转 this. router操作路由跳转this.router.push({ name:‘hello’, query:{ username:‘word’, age:‘11’ } })
r o u t e 读取路由参数接收 v a r n a m e = t h i s . route读取 路由参数接收 var name = this. route读取路由参数接收varname=this.route.query.username;
s

路由配置里面设置路由路径时也可以带参数
const routes = [
{ path: ‘/users/:id’, component: User },
]
代码中的**id **字段,就是路径参数,当使用params的时候,就可以获取到。this.$router. params.id

通过params传参, path会忽略params 所以path不能和params一起使用
注意:这里使用name路由跳转方式路径不需要加 / 因为它只是个名字
this. r o u t e r . p u s h ( n a m e : " H o m e " , p a r a m s : i d : t h i s . i d ) 另一个页面接收 : 这里使用 p a r a m s 传参就需要写 p a r a m s 接收 t h i s . router.push({ name:"Home", params:{ id:this.id } }) 另一个页面接收: 这里使用params传参就需要写params接收 this. router.push(name:"Home",params:id:this.id)另一个页面接收:这里使用params传参就需要写params接收this.route.params.id

通过query传参,path 和 name路由跳转方式,都可以用query传参
this. r o u t e r . p u s h ( p a t h : " / S e a r c h " , q u e r y : / / q u e r y 是个配置项 a g e : 20 ) 或者 t h i s . router.push({ path:"/Search", query:{ //query是个配置项 age:20 } }) 或者 this. router.push(path:"/Search",query://query是个配置项age:20)或者this.router.push({
name:“Search”,
query:{ //query是个配置项
age:20
}
})
另一个页面接收
this.$route.query.age
query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数

总结:

  1. query和params区别:
    query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数
    params相当于POST请求,参数不会在地址栏中显示
  2. 使用path方式跳转路由 path会忽略params 所以path不能和params一起使用
    推荐使用name和params方式实现路由跳转
  3. params传参,push里面只能是 name:‘xxx’,不能是path:‘/xxx’,因为params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值