Vue中实现路由跳转的三种方式详细分解

Posted 小马大咖

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue中实现路由跳转的三种方式详细分解相关的知识,希望对你有一定的参考价值。

vue中实现路由跳转的三种方式

目录

vue中实现路由跳转的三种方式

一、使用vue-router 

1.下载vue-router模块到当前工程 

2.在main.js中引入VueRouter函数

3.添加到Vue.use()身上 – 注册全局RouterLink和RouterView组件

4.创建路由规则数组 – 路径和组件名对应关系

5.用规则生成路由对象

6.把路由对象注入到new Vue实例中

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

二、声明式-router-link 【实现跳转最简单的方法】 

1.可用组件router-link来替代a标签

2.在跳转路由时, 可以给路由对应的组件内传值 

三、编程式-用JS代码来进行跳转 

一、$ router 和 $ route的区别

二、路由跳转方式name 、 path 和传参方式params 、query的区别(重要)


一、使用vue-router 

vue-router 本质是一个第三方的包 用的时候需要下载 

详细步骤 (7步法 ):

1.下载vue-router模块到当前工程 

 npm i vue-router

2.在main.js中引入VueRouter函数

// 引入路由
import VueRouter from "vue-router";

3.添加到Vue.use()身上 – 注册全局RouterLink和RouterView组件

// 注册全局
Vue.use(VueRouter)

4.创建路由规则数组 – 路径和组件名对应关系

创建路由规则数组(需要准备切换的页面组件)把准备好的页面组件引入到main.js中

const routes = [
            path: "/",
            redirect: "find" //默认显示推荐组件(路由的重定向)
        ,
        
            path: "/find",
            name: "Find",
            component: Find,
            //二级路由
            children: [
                    path: "/",
                    redirect: "recom" //默认显示推荐组件
                ,
                
                    path: "ranking", //注意二级路由的路径千万不要加/
                    component: Ranking
                ,
                
                    path: "songlist",
                    component: SongList
                ,
            ]
        ,
        
            path: "/my",
            name: "My",
            component: My
        ,
        
            path: "/part",
            name: "Part",
            component: Part
        ,

        
            path: "*",
            component: NotFound //定义找不到已有组件时显示404
        ,
    ]

5.用规则生成路由对象

    // 创建路由对象并且传入规则
const router = new VueRouter(
    routes,
    mode: "history" //路由模式(默认为hash模式)
)

6.把路由对象注入到new Vue实例中

new Vue(
    router, //导入路由对象
    render: h => h(App),
).$mount('#app')

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

当url的hash值路径切换,显示规则里对应的组件

 router-view 实现路由内容的地方,引入组件时写到需要引入的地方 需要注意的是,使用vue-router控制路由则必须router-view作为容器。(可以先引入根组件App.vue中进行自测)

注意: 一切都要以url上hash值为准 

二、声明式-router-link 【实现跳转最简单的方法】 

1.可用组件router-link来替代a标签

  • router-link 是vue-router提供了一个全局组件
  • router-link实质上最终会渲染成a链接 to属性等价于提供 href属性(to无需#)
  • router-link提供了声明式导航高亮的功能(自带类名)

代码如下:

<template>
  <div>
    <div class="footer_wrap">
      <router-link to="/find">发现音乐</router-link>
      <router-link to="/my">我的音乐</router-link>
      <router-link to="/part">朋友</router-link>
    </div>
    <div class="top">
      <router-view></router-view>
    </div>
  </div>
</template>
//在控制台元素检查时会发现激活的类名 在样式style中定义高亮样式 点击时就会高亮

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

2.在跳转路由时, 可以给路由对应的组件内传值 

在router-link上的to属性传值, 语法格式如下 :

(方式一)

to=/path?参数名=值

例:to="/part?name=张三"

对应页面组件接收传递过来的值 

$route.query.参数名

接收数据:$route.query.name

(方式二)

to=“/path/值” (需在路由规则里配置/path/:参数名)

例:to="/part/李四"

配置:path:"/part/:username"

 对应页面组件接收传递过来的值 (注意动态参数需要用params接收)

$route.params.参数名

接收数据:$route.params.username

三、编程式-用JS代码来进行跳转 

用JS代码来进行跳转

语法: path或者name任选一个

一、$ router $ route的区别

$router : 是路由操作对象,只写对象

$route : 路由信息对象,只读对象 

$ router操作路由跳转 

this.$router.push( name:‘hello’, query: name:‘word’, age:‘11’  )

$route读取 路由参数接收

var name = this.$route.query.name;

二、路由跳转方式name 、 path 和传参方式params 、query的区别(重要)

path 和 name路由跳转方式,都可以用query传参

  • 使用path方式跳转路由 path会忽略params 所以path不能和params一起使用
  • 推荐使用name和query方式实现路由跳转

params传参,push里面只能是 name:‘xxx’,不能是path:‘/xxx’,因为params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined!!! 

通过params传参

==注意:==这里使用name路由跳转方式路径不需要加 / 因为它只是个名字 

this.$router.push(
    name:"Home",
    params:
        id:this.id
    
)

 另一个页面接收:

这里使用params传参就需要写params接收

this.$route.params.id

通过query传参 

this.$router.push(
    path:"/Search",
    query: //query是个配置项
        age:20
    
)

另一个页面接收

this.$route.query.age

query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数

uery传参**

this.$router.push(
    path:"/Search",
    query: //query是个配置项
        age:20
    
)

另一个页面接收

this.$route.query.age

总结:
query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数

params相当于POST请求,参数不会在地址栏中显示

vue路由跳转的三种方式

vue路由跳转的三种方式

<router-link to=‘需要跳转到的页面的路径>

浏览器在解析时,将它解析成一个类似于<a> 的标签。

div和css样式略

 <li >
        <router-link to="keyframes">点击验证动画效果 </router-link>  
 </li>

别忘记给需要跳转的路径在需要提前在router/index.js下引入哦。  

2、this.$router.push({ path:’/user’})

常用于路由传参,用法同第三种

区别:

1.query引入方式
params只能用name来引入路由
而query 要用path引入

2.query传递方式
类似于我们ajax中get传参,在浏览器地址栏中显示参数
params则类似于post,在浏览器地址栏中不显示参数

helloworld.vue文件中

<template>
.....
<li @click="change">验证路由传参</li>
</template>
 
<script>
export default {
  data () {
    return {
      id:43,  //需要传递的参数
    }
  },
  methods:{
    change(){
      this.$router.push({  //核心语句
        path:‘/select‘,   //跳转的路径
        query:{           //路由传参时push和query搭配使用 ,作用时传递参数
          id:this.id , 
        }
      })
    }
  }
}
</script>

select.vue文件中

<template>
  <select>
          <option value="1" selected="selected">成都</option>
          <option value="2">北京</option>
      </select>
</template>
 
<script>
    export default{
        data(){
            return{
                id:‘‘,
            }
        },
        created(){  //生命周期里接收参数
            this.id = this.$route.query.id,  //接受参数关键代码
            console.log(this.id)  
        }
    }
</script>

可以在使用的标签中通过v-if = ‘id == 1’ 或者else-if = ‘id == 2‘等进行区分拼接

3、this.$router.replace{path:‘/’ }类似,不再赘述

以上是关于Vue中实现路由跳转的三种方式详细分解的主要内容,如果未能解决你的问题,请参考以下文章

如何在vue中实现路由跳转判断用户权限功能

Vue-Router来实现组件间跳转的三种方法

vue路由跳转的三种方式

vue.js关于路由的跳转

vue中实现 ‘换肤 / 切换样式主题’ 功能的三种方式详解(干货)

vue传参的三种方式