js获取url并截取相应的字段,js解决url获取中文字段乱码问题

相信url截取信息是一个很常用的小功能
页面跳转传参的时候可以在A页面的url挂一些参数到B页面获取
正常的页面传参都是以数字和英文为主
正常情况下中文获取的时候是有乱码的
所谓上有政策下有对策
一个正常的url(http://网址?areaInfo=13394186.192948427,3695040.8525992734&lines=1&nameId=7665&name=九州县令)
平时写的url截取方法

function qs (name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
var r = window.location.search.substr(1).match(reg);
if (r != null) return unescape(r[2]);
return null;
}

取值的话很简单直接 qs('参数名')就可以了但是这样的话取name字段的话会出现乱码

function qs () {
var url = window.location.search;
var thisUrl = new Object();
if (url.indexOf("?") != -1) {
var str = url.substr(1);
strs = str.split("&");
for(var i = 0; i < strs.length; i ++) {
thisUrl[strs[i].split("=")[0]]=decodeURI(strs[i].split("=")[1]);
}
}
return thisUrl;
}

这样的话会解决中文取值乱码问题
取值方式 qs().name

希望对大家能有帮助

posted @ 2020-06-11 10:02  九州县令  阅读(557)  评论(0编辑  收藏  举报