当前位置:网站首页>Some problems with passing parameters of meta and params in routing (can be passed but not passed, empty, collocation, click to pass multiple parameters to report an error)
Some problems with passing parameters of meta and params in routing (can be passed but not passed, empty, collocation, click to pass multiple parameters to report an error)
2022-08-04 21:08:00 【Delete your code in the middle of the night】
When a routing object does not need to display a component, it can be set through meta
No Footer is required for login and registration, it can be solved by routing meta configuration
The path judgment can be obtained from the route, but it is troublesome
Through the routing configuration, configure the meta settings in the routing object to do it
{
path:'/login',
component:Login,
// Meta setting object, which can configure any data you want to match
meta:{
isHidden:true
}
},
Question 1:
Can I use the combination of path and params configuration when specifying the params parameter? (object writing)
Cannot use the combination of path and params configuration,
only use the combination of name and params configuration
queryConfiguration can be combined with path or name
Question 2:
How to specify whether the params parameter can be passed or not?
Path: '/search/:keyword?'
Question 3:
If you specify the name and params configuration, but the data in params is a "", you cannot jump, and the path will be a problem
The premise is that the routing params parameters can be passed or not
Solution 1: Do not specify params
Solution 2: Specify the params parameter value as undefined
Question 4:
Can routing components pass props data?
Yes: You can map/convert the query or params parameters into props and pass them to the routing component object
Implementation: props: (route)=>({keyword1:route.params.keyword, keyword2: route.query.keyword })
Question 5:
vue_router version 3.1.0 and above introduces the syntax of promise:
If we pass parameters without modifying the parameters and click multiple times at the same time, such an error will be thrown
Uncaught (in promise) NavigationDuplicated, the reason isThe internal promise is failed, and we didn't deal with it. Solution 1: Downgrade version, not good. Solution 2: Process the failed promise and add .catch(() => {}) after the push callNot good, I have to add it every time, trouble
Solution 3: Modify the source code, once and for all
The push method has three parameters:
1. The matching route (can be a route path string or a route object)
2. Successful callback
3. Failed callback
The push method wants to not report an error
vue-router.esm.js?3423:2065 Uncaught (in promise) NavigationDuplicated:
Avoided redundant navigation to current location: "/search/aa?keyword1=AA".
When passing parameters, at least one of the callbacks for success and failure must be passed
According to the source code analysis, if at least one processing function is passed, then the intervention of promise will not be triggered. If none are passed, then
Promise intervention will be introduced, and if we do not handle the failed callback function, an exception will be thrown and an error will be reported
if (!onComplete && !onAbort && typeof Promise !== 'undefined') {
return new Promise(function (resolve, reject) {
this$1.history.push(location, resolve, reject);
});
} else {
this.history.push(location, onComplete, onAbort);
} }
Configure in the router
// The method called by this.$router.push is the following method// 1. Save the previous push method to prevent the loss of later modificationsconst originPush = VueRouter.prototype.pushconst originReplace = VueRouter.prototype.replace// 2. Modify the push method on the prototype, so that when I call it later, my modified push method is calledVueRouter.prototype.push = function(location, resolved, rejected) {if(resolved === undefined && rejected === undefined){return originPush.call(this,location).catch(() => {})}else{return originPush.call(this,location,resolved,rejected)}}VueRouter.prototype.replace = function(location, resolved, rejected) {if(resolved === undefined && rejected === undefined){return originReplace.call(this,location).catch(() => {})}else{return originReplace.call(this,location,resolved,rejected)}}边栏推荐
- 简述@RequestParam与@RequestBody参数注解
- laravel whereDoesntHave
- web漏洞扫描器-awvs
- Five Minutes Introductory Text Processing Three Musketeers grep awk sed
- 【一起学Rust | 进阶篇 | Service Manager库】Rust专用跨平台服务管理库
- 三种方式设置特定设备UWP XAML view
- STM32MP157A驱动开发 | 01- 板载LED作为系统心跳指示灯
- 动手学深度学习_NiN
- 数据仓库(1)什么是数据仓库,数仓有什么特点
- SPSS-System Clustering Hand Calculation Practice
猜你喜欢

Retrofit的使用及原理详解

Getting Started with Lattice Passwords

Using Baidu EasyDL to realize forest fire early warning and identification

DICOM医学影像协议

web漏洞扫描器-awvs

Zero-knowledge proof notes - private transaction, pederson, interval proof, proof of ownership

PowerCLi 导入License到vCenter 7

Five Minutes Introductory Text Processing Three Musketeers grep awk sed

宝塔实测-搭建中小型民宿酒店管理源码

for 循环中的 ++i 与 i++
随机推荐
用 Excel 爬取网络数据的四个小案例
暴雨中的人
Feign 与 OpenFeign
Win10 uwp use ScaleTransform magnify an element
【1403. 非递增顺序的最小子序列】
STP基本配置及802.1D生成树协议的改进
动态规划_双数组字符串
Dotnet using WMI software acquisition system installation
【学术相关】清华教授发文劝退读博:我见过太多博士生精神崩溃、心态失衡、身体垮掉、一事无成!...
matlab drawing
2、字符集-编码-解码
【PCBA方案设计】握力计方案
后缀式的计算
run command for node
拼多多开放平台订单信息查询接口【pdd.order.basic.list.get订单基础信息列表查询接口(根据成交时间)】代码对接教程
QT(41)-多线程-QTThread-同步QSemaphore-互斥QMutex
LayaBox---TypeScript---首次接触遇到的问题
laravel whereDoesntHave
Retrofit的使用及原理详解
win10 uwp 使用 WinDbg 调试