JS获取URL中参数,支持多参数传值传参,支持中文

网友投稿 1648 2022-09-26

js获取URL中参数,支持多参数传值传参,支持中文

JS获取URL中参数,支持多参数传值传参,支持中文

名称:​​js实现页面与页面之间传值​​

url:​​js实现页面与页面之间传值的三种方法_cplvfx的博客-CSDN博客_js页面传参​​

推荐使用:

// 获取url中参数function getQueryVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i = 0; i < vars.length; i++) { var pair = vars[i].split("="); if (pair[0] == variable) { return pair[1]; } } return ('');}

示例代码:

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

第一:页面代码

JS URL多参数传值,支持中文 开始传参

level
tit_h2

第二:知识点刨析

js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent

1 escape()函数

定义和用法  escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串。 语法  escape(string) 参数  描述   string  必需。要被转义或编码的字符串。  返回值  已编码的 string 的副本。其中某些字符被替换成了十六进制的转义序列。 说明  该方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。其他所有的字符都会被转义序列替换。

2 encodeURI()函数

定义和用法  encodeURI() 函数可把字符串作为 URI 进行编码。 语法  encodeURI(URIstring) 参数  描述   URIstring  必需。一个字符串,含有 URI 或其他要编码的文本。  返回值  URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。 说明  该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。 该方法的目的是对 URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的:;/?:@&=+$,#

3 encodeURIComponent() 函数

定义和用法  encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。 语法  encodeURIComponent(URIstring) 参数  描述   URIstring  必需。一个字符串,含有 URI 组件或其他要编码的文本。  返回值  URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。 说明  该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。 其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。 提示和注释  提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。

4 总结:

通过对三个函数的分析,我们可以知道:escape()除了 ASCII 字母、数字和特定的符号外,对传进来的字符串全部进行转义编码,因此如果想对URL编码,最好不要使用此方法。而encodeURI() 用于编码整个URI,因为URI中的合法字符都不会被编码转换。encodeURIComponent方法在编码单个URIComponent(指请求参数)应当是最常用的,它可以讲参数中的中文、特殊字符进行转义,而不会影响整个URL。

1、   传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。

例如: 输出结果: Visit%20W3School%21 %3F%21%3D%28%29%23%25%26

2 encodeURI()

输出结果:​​​ ,/?:@&=+$# 对整个URL进行编码,而URL的特定标识符不会被转码。

3  encodeURIComponent()

例1: 输出结果: %2C%2F%3F%3A%40%26%3D%2B%24%23 对URL中的参数进行编码,因为参数也是一个URL,如果不编码会影响整个URL的跳转。 摘自:

作者:XingKong22star

文章名称:js 中编码(encode)和解码(decode)的三种方法

地址:http://blog.csdn-/xingkong22star/article/details/39155739

附加延伸参考文献:

作者:cookie-niu

文章名称:JS对URL字符串进行编码/解码分析

地址:http://blog.csdn-/lishimin1012/article/details/52823528

橙说:这篇文章以百度URL为例,图文并茂进行解读,有兴趣的朋友可以去看下!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:springboot框架阿里开源低代码工具LowCodeEngine
下一篇:MongoDB安装+将MongoDB服务器作为Windows服务运行
相关文章

 发表评论

暂时没有评论,来抢沙发吧~