超详细!总结vue实现路由跳转的3种方式!
时间:2022-08-10 17:15
vue-router 本质是一个第三方的包 用的时候需要下载【相关推荐:vue.js视频教程】 步骤 (7步法 ): 1.下载 2.在main.js中引入VueRouter函数 3.添加到Vue.use()身上 – 注册全局RouterLink和RouterView组件 4.创建路由规则数组 – 路径和组件名对应关系 创建路由规则数组(需要准备切换的页面组件)把准备好的页面组件引入到main.js中 5.用规则生成路由对象 6.把路由对象注入到new Vue实例中 7.用 当url的hash值路径切换,显示规则里对应的组件 注意:一切都要以url上hash值为准 代码如下: router-link好处 : 自带激活时的类名, 可以做高亮 在router-link上的to属性传值, 语法格式如下 : (方式一) to=/path?参数名=值 例: 对应页面组件接收传递过来的值 $route.query.参数名 接收数据:$route.query.name (方式二) to=“/path/值” (需在路由规则里配置/path/:参数名) 例: 配置: 对应页面组件接收传递过来的值 (注意动态参数需要用params接收) $route.params.参数名 接收数据:$route.params.username 用JS代码来进行跳转 语法: path或者name任选一个 $router : 是路由操作对象,只写对象 $route : 路由信息对象,只读对象 $ router操作路由跳转 $route读取 路由参数接收 path 和 name路由跳转方式,都可以用query传参 params传参,push里面只能是 name:‘xxx’,不能是path:‘/xxx’,因为params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined!!! 通过params传参 ==注意:==这里使用name路由跳转方式路径不需要加 另一个页面接收: 这里使用params传参就需要写params接收 通过query传参 另一个页面接收 query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数 uery传参** 另一个页面接收 总结: params相当于POST请求,参数不会在地址栏中显示 以上就是超详细!总结vue实现路由跳转的3种方式!的详细内容,更多请关注gxlsystem.com其它相关文章!一、使用vue-router
vue-router
模块到当前工程 yarn add vue-router
// 引入路由import VueRouter from "vue-router";
// 注册全局Vue.use(VueRouter)
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
},
]
// 创建路由对象并且传入规则const router = new VueRouter({
routes,
mode: "history" //路由模式(默认为hash模式)})
new Vue({
router, //导入路由对象
render: h => h(App),}).$mount('#app')
router-view
作为挂载点, 切换不同的路由页面router-view
实现路由内容的地方,引入组件时写到需要引入的地方 需要注意的是,使用vue-router控制路由则必须router-view作为容器。(可以先引入根组件App.vue中进行自测)二、声明式-router-link 【实现跳转最简单的方法】
1.可用组件router-link来替代a标签
router-link
是vue-router提供了一个全局组件<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中定义高亮样式 点击时就会高亮
2.在跳转路由时, 可以给路由对应的组件内传值
to="/part?name=小明"
to="/part/小王"
path:"/part/:username"
三、编程式-用JS代码来进行跳转
一、
$ router
和 $ route
的区别this.$router.push({ name:‘hello’, query:{ name:‘word’, age:‘11’ } })
var name = this.$route.query.name;
二、路由跳转方式name 、 path 和传参方式params 、query的区别(重要)
/
因为它只是个名字this.$router.push({
name:"Home",
params:{
id:this.id }})
this.$route.params.id
this.$router.push({
path:"/Search",
query:{ //query是个配置项
age:20
}})
this.$route.query.age
this.$router.push({
path:"/Search",
query:{ //query是个配置项
age:20
}})
this.$route.query.age
query相当于GET请求,页面跳转的时候,可以在地址栏看到请求参数