重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍了vue3.0 CLI - 3.2路由怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
创新互联专注于茂南网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供茂南营销型网站建设,茂南网站制作、茂南网页设计、茂南网站官网定制、小程序开发服务,打造茂南网络公司原创品牌,更为您提供茂南网站排名全网营销落地服务。
动态路由
在路由某部分里加入[ : ],就成为动态路由如:/user/:id/,那么路由导航,并不是 /user/id/ 而是 /user/666/。
显然这个 id 能被获取,在组件中使用。通过 this.$route.params 获取。 this 是当前组件,$route 是路由对象,params 是一个对象字面量 { id:666 }。
$route 通过 Vue.use(Router)
和 new Vue({ router, store, render: h => h(App) }).$mount('#app')
全局依赖注入,在所有组件中都可以使用它。
1、router.js 中 path: '/about' 路由 改为 path: '/about/:id'。
2、About.vue 中
3、About.vue 中 data 或者 computed 属性中添加 isActive: function () { return this.$route.params.id === "666"; }
4、App.vue 中
5、About.vue 中
保存点击【VUE】导航按钮,即可见到效果:
如何取得 $route 中参数的值,便是很大的进步。这个参数可以用在任何地方,可以用来做任何事情。
比如传递数据,根据路由参数动态从服务器获取组件内容等
在进行下一个内容学习之前,commit 一下。
嵌套路由(子路由)
在页面,通常存在多级导航。vue 官方网站便是多级导航的例子:顶部为一级导航栏,左侧为二级导航栏。
导航通常对应
并非只有 App.vue 中才能存在
下面把 HelloWorld.vue 变为 About.vue 的子路由:
1、
2、router.js 中关于 About.vue 组件的路由 替换为
{ path: '/about/:id', 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/About.vue'), children: [ { path: '1', component: HelloWorld, props: (router) => ({ msg: router.query.msg }) } ] }
在浏览器地址栏输入 http://localhost:8081/#/about/666/1?msg='welcome to nDos blog' 查看效果。
编程式导航与路由命名
在 vue 初始化的工程中,路由配置时,组件都已做好命名。这便是路由命名。
编程式导航,尽量使用命名的路由,如下:
router.push({ name: 'about', params: { userId: 123 }})
因为使用 path 属性进行编程式导航,params 无效。
这样使用路由跳转,使得单页面编程的路由跳转更加灵活。比如某个跳转按钮,可以绑定函数,进行条件跳转。
关于这两个的内容并不多,参照官网教程学习。
命名视图
在一个组件中,如果有多个组件出口,比如:在某个页面,需要同时展示很多个组件时。
只有一个
多个
在 router.js 中的 components 属性中,添加多个组件即可 ( 到这里才明白为什么 components 为什么是复数形式的写法 )。
感谢你能够认真阅读完这篇文章,希望小编分享的“vue3.0 CLI - 3.2路由怎么用”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!