IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue-router 面试问题整理 -> 正文阅读

[JavaScript知识库]vue-router 面试问题整理

路由跳转有几种方式:
声明式导航:router-link(务必要有to属性),可以实现路由的跳转
编程式导航:利用的是组件实例的$router.push|replace 方法,可以实现路由的跳转(可以书写一些自己的业务)

路由传参:

parmas 传参:属于路径当中的一部分,需要注意,在配置路由的时候,需要占位

query 参数:不属于路径当中的一部分,类似于ajax 中的queryString ? /home?k=v&kv=, 不需要占位


路由参数:
第一种:字符串形式

this.$router.push('/search/'+this.keyword+"?k="+this.keyword.toUpperCase());

this.$route.params.keyword

this.$route.query.k

第二种:模板字符串

this.$router.push(`/search/${this.keyword}?k=${this.keyword.toUpperCase()}`)

第三种:对象形式 ?(事先给路由组件添加name参数)

this.$router.push({name:'search',params:{keyword:this.keyword},query:{k:this.keyword.toUpperCase()} })


路由组件是可以接收 props 形式的参数

编程式导航跳转报警告错误的解决方法:


1:编程式路由跳转到当前路由(参数不变),多次执行会抛出NavigationDuplicated的警告错误?--路由跳转有两种形式:声明式导航、编程式导航
--声明式导航没有这类问题的,因为vue-router底层已经处理好了1.1为什么编程式导航进行路由跳转的时候,就有这种警告错误那?"vue-router" : "个3.5.3":最新的vue-router引入promise
1.2通过给push方法传递相应的成功、失败的回调函数,可以捕获到当前错误,可以解决。|
治标不治本的方法:
编程式导航返回的结果是promise ,给它添加成功的回调函数,和失败的回调函数处理异常

this.$router.push({name:'search',params:{keyword:this.keyword},query:{k:this.keyword.toUpperCase()} ()=>{},()=>{}})

治标治本的方法:

let originPush=VurRouter.prototype.push;
VueRouter.prototype.push=function(location,resolve,reject){
?? ?if(resolve && reject){
?? ??? ?originPush.call(this.location,resolve,reject);
?? ?}else{
?? ??? ?originPush.call(this,location,()=>{},()=>{});
?? ?}
}


let originReplace=VueRouter.prototype.replace;

VueRouter.protorype.replace=function(location,resolve,reject){
?? ?if(resolve && reject){
?? ??? ?originReplace.call(this,location,resolve,reject);
?? ?}else{
?? ??? ?originReplace.call(this,location,()=>()=>{});
?? ?}
}

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-13 12:43:13  更:2021-12-13 12:43:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 2:16:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码