使用Vue路由Hash模式引发的一场血案

栏目: IT技术 · 发布时间: 4年前

内容简介:路径1:https://xxxxx.djtest.cn/driver-register/index.html?hmsr=qqqqq#/register路径2:

背景

路径1:

https://xxxxx.djtest.cn/driver-register/index.html?hmsr=qqqqq#/register

路径2:

https://xxxxx.djtest.cn/driver-register/index.html#/register?hmsr=qqqqq

大家平常用那个什么格式的链接,路径1还是路径2????

我一直习惯用路径2,可是就在前不久出现了一个线上bug:sob::sob::sob:。这个bug原因还是路径不规范造成的,当是我一脸懵逼,我是谁,我在哪????

url的组成

协议部分、域名部分、端口部分、虚拟目录部分、文件名部分、参数部分、锚部分

使用Vue路由Hash模式引发的一场血案
注:端口不是一个URl必须的部分,如果省略端口部分,将采用默认端口。

相信大家对于url每一部分都很了解。在这就简单提一下,就不浪费大家的时间了。

使用中遇到的问题

问题1:

【路径1】和【路径2】都能正常打开页面,它们的区别是什么,谁才是规范的url?

【路径1】锚部分

使用Vue路由Hash模式引发的一场血案

【路径2】锚部分

使用Vue路由Hash模式引发的一场血案

通过控制台的输出,我们发现两个路径打印出来的参数部分和锚部分是不一样,为啥??

url的锚部分是从“#”开始到最后,都是锚部分。锚部分不是url的必需部分。 url的参数部分是从“?”开始到“#”为止之间的部分。参数部分也不是url的必需部分。根据url参数部分和锚部分的定义以及控制台输出的结果,我们可以得出【路径1】是符合规范url。

问题2:

由问题1得出【路径1】是符合url规范的路径。但是在开发中我发现问题又来了,用this.$route.query 无法获取参数?在页面中增加代码(如下)

created() {

console.log('*******************')

console.log('this.$route.query.hmsr:'+this.$route.query.hmsr)

console.log('window.location.search:'+window.location.search)

console.log('*******************')

}

查看打印结果

【路径1】:

使用Vue路由Hash模式引发的一场血案

【路径2】:

使用Vue路由Hash模式引发的一场血案

why???

我查阅vue router相关文档,对此并没有说明,自己猜想应该是vue router内部做了相应的处理。

问题就来了,我们应该在项目中如何获取参数呢?

写一个获取参数的通用方法:

function getUrlParam(key) {

var url = window.location.href;

var startIndex = url.indexOf('?');

var params = {};

if (startIndex > -1) {

var str = url.substring(startIndex + 1);

var arr = str.split('&');

for (var i = 0; i < arr.length; i++) {

var kv = arr[i].split('=');

if (kv[1].indexOf('#') > -1) {

kv[1] = kv[1].substring(0, kv[1].indexOf('#'));

}

params[kv[0]] = kv[1];

}

}

return params[key];

}

【路径1】

使用Vue路由Hash模式引发的一场血案

【路径2】

使用Vue路由Hash模式引发的一场血案

注意:在传统模式开发中,如果在url中search与hash同时存在,你的hash值一定要放在search后面。

问题3:

通过上面获取参数方法,【路径1】和【路径2】都能获取到了对应的参数,这回没有问题了吧,但是想象很美好,现实很残酷。

现实是这样的,h5页面放到app中时,会在配置的路径上添加一些参数。app开发人员添加规则是在锚部分的前面添加参数。但是如果我们的页面使用vue-router进行页面跳转同时增加参数,url上就会出现双“ ?”的情况,那参数还能获取吗?

使用Vue路由Hash模式引发的一场血案

怎么办后面一个问号的参数获取不到?

方案一:优化获取参数函数,使其能获取多问号的参数

function getUrlAllParam(...args) {

if (args.length === 0) return undefined

const url = decodeURIComponent(window.location.href)

const reg = args.length === 1

? new RegExp(`[&?]${args[0]}=([^&%#]+)`)

: new RegExp(`[&?](?:${args.join('|')})=([^&%#]+)`)


const matchArray = url.match(reg)


return matchArray === null ? undefined : matchArray[1]

}

调用:

this.getUrlAllParam('hmsr') //获取参数的key

使用Vue路由Hash模式引发的一场血案

方案二: 不使用vue router跳转。跳转之前把要跳转的路径拼接好,再跳转,让路径中不存双问好的问题。

fomartUrl(url,params,hash){

// url 是访问路径 字符串(不包含参数部分和锚部分的)

// params 参数是数组[{name:'hmsr',value:'1222'}]

if(!url){

return false;

}

let query = '';

if(params && params.length>0){

let queryAttr =[];

for(let i =0;params.length>i;i++){

queryAttr.push(params[i].name + '=' +params[i].value)

}

query = queryAttr.join('&')

}

if(hash){

return url + '?' + query + '#/' + hash

} else {

return url + '?' + query

}

}


调用:

const goHref = this.fomartUrl(

'http://localhost:8080/',

[{name:'hmsr',value:'2222'},{name:'aaa',value:'11'}],

'outsideIndex')


window.location.href = goHref

使用Vue路由Hash模式引发的一场血案

总结

这是在开发过程中,遇到的一些与url参数部分和锚部分相关的问题以及自己的解决方案。各位大佬如果有更好解决方案,欢迎加群指导交流。

  • 如果感觉写得不错,关注下微信公众号  [前端巅峰]
  • 我是 Peter ,架构设计过20万人端到端加密超级群功能的桌面IM软件,我微信: CALASFxiaotan
  • 另外欢迎收藏我的资料网站:前端生活社区: https://qianduan.life ,可以右下角点个在看,关注一波公众号: [前端巅峰]

以上所述就是小编给大家介绍的《使用Vue路由Hash模式引发的一场血案》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

科技投资新时代:TMT投资方法、趋势与热点聚焦

科技投资新时代:TMT投资方法、趋势与热点聚焦

马军、宋辉、段迎晟 / 人民邮电出版社 / 2018-3 / 69.00

中国 TMT 行业(科技、媒体及通信)起步较晚但充满朝气。2017 年,TMT 板块的IPO 数量占到了总数的四分之一;对于投资者来说,投资 TMT 的收益非常可观。那么,TMT 的投资趋势如何? TMT 行业又有哪些投资热点? 本书立足于 TMT 投资现状,在介绍了 TMT 投资的基本概念之后,作者详细讲述了TMT 投资的基本研究方法、分析视角、整体行情及趋势分析,同时从行业视角分析了包括......一起来看看 《科技投资新时代:TMT投资方法、趋势与热点聚焦》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

随机密码生成器
随机密码生成器

多种字符组合密码