最近项目中遇到一个这样问题,在页面跳转时,追加了location.search,有中文字符,但是在分享第二次时,这个链接无法获取中文字段,变成乱码。
仔细对比,发现在页面分享时,浏览器自动对中文进行了二次加密,所以需要二次解密,才可以获取字段值。
eg. location.href = "index.html?provinceName="+"江苏";
location.search = "?provinceName=%25E6%25B1%259F%25E8%258B%258F%25E7%259C%2581"
分享以后:
location.search = "?provinceName=%2525E6%2525B1%25259F%2525E8%25258B%25258F%2525E7%25259C%252581"
这样就对江苏进行了2次加密。
针对这个问题,2种解决方案:
1>自己封装加密方法,对加密的中文用英文显示,这样浏览器就不会做二次加密了。
2>可以通过循环,直到解密成中文。
pms:function(name){
var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
var r = location.search.substr(1).match(reg);
if (r) {
return decodeURI(r[2]);
}
return null;
}
var provinceName= api.pms('provinceName');
while(provinceName.indexOf('%')>-1){
provinceName= decodeURI(provinceName);
}
也可以做一个公共组件
function(name){
var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
var r = location.search.substr(1).match(reg);
if (r) {
while(r[2].indexOf('%')>-1){
r[2]= decodeURI(r[2]);
}
return r[2];
}
return null;
}
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 智能桌面机器人:用.NET IoT库控制舵机并多方法播放表情
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· DeepSeek火爆全网,官网宕机?本地部署一个随便玩「LLM探索」
· 开发者新选择:用DeepSeek实现Cursor级智能编程的免费方案
· 【译】.NET 升级助手现在支持升级到集中式包管理
· 独立开发经验谈:如何通过 Docker 让潜在客户快速体验你的系统
· Tinyfox 发生重大改版