vue3.0 CLI - 3.2 路由的初级使用教程
我的 github 地址 -vue3.0Study - 阶段学习成果都会建立分支。
==========================
动态路由
在路由某部分里加入[ : ],就成为动态路由如:/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 中 <top-nav title="军事" :class="{ active: isActive }"/> 添加红色部分。
3、About.vue 中 data 或者 computed 属性中添加 isActive: function () { return this.$route.params.id === "666"; }
4、App.vue 中 <router-link to="/about/666">VUE</router-link>
5、About.vue 中 <style lang="less"> .active { background: red; } </style>
保存点击【VUE】导航按钮,即可见到效果:
如何取得 $route 中参数的值,便是很大的进步。这个参数可以用在任何地方,可以用来做任何事情。
比如传递数据,根据路由参数动态从服务器获取组件内容等
在进行下一个内容学习之前,commit 一下。
嵌套路由(子路由)
在页面,通常存在多级导航。vue 官方网站便是多级导航的例子:顶部为一级导航栏,左侧为二级导航栏。
导航通常对应 <router-link> 而 <router-link> 与 <router-view/> 对应。
并非只有 App.vue 中才能存在 <router-view/>, 任何组件都可以。
下面把 HelloWorld.vue 变为 About.vue 的子路由:
1、<HelloWorld msg="vue 官方相关资料的链接"/> 替换为 <router-view/>
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-view/> 显然不能满足需求。
多个 <router-view/> 同时存在的时候,就必须要加以区分,用的是 name 属性:<router-view name="a"/>
在 router.js 中的 components 属性中,添加多个组件即可 ( 到这里才明白为什么 components 为什么是复数形式的写法 )。
总结
以上所述是小编给大家介绍的vue3.0 CLI - 3.2 路由的初级使用教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- [先行者周日课程-0305] web前端组件 之 拖动窗口
- react-native城市列表组件
- [前端常见病] 之 后端数据还没有,前端怎么进行?
- dependencies与devDependencies的区别
- [先行者课程] -- 用js实现倒计时功能的业务逻辑
- iOS如何实现多个环境一次打包
- 从原理到策略算法再到架构产品看推荐系统 | 附Spark实践案例
- MobX 在 React Native开发中的应用
- RCTEventEmitter使用
- Google V8 引擎
- 揭秘前端字符的戏精之路
- 跨语言嵌入模型的调查
- React Native如何消除启动时白屏
- 如何在Python中将TimeDistributed层用于Long Short-Term Memory Networks
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Laravel 5.5 实现禁用用户注册示例
- 解决php用mysql方式连接数据库出现Deprecated报错问题
- Laravel自动生成UUID,从建表到使用详解
- Python中Selenium库使用教程详解
- 浅谈laravel aliases别名的原理
- Yii2框架中一些折磨人的坑
- php获取是星期几的的一些常用姿势
- laravel 实现用户登录注销并限制功能
- PHP Swoole异步Redis客户端实现方法示例
- PHP全局使用Laravel辅助函数dd
- 在laravel中实现ORM模型使用第二个数据库设置
- laravel5.1 ajax post 传值_token示例
- Laravel框架处理用户的请求操作详解
- Laravel实现ORM带条件搜索分页
- Laravel等框架模型关联的可用性浅析