前台js获取url传递参数(后台Request.QueryString接收)

1、方法

function GetQueryString(name)
{
       var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return decodeURIComponent(r[2]); return null;
}
 
// 调用方法
alert(GetQueryString( "参数名1" ));
alert(GetQueryString( "参数名2" ));
alert(GetQueryString( "参数名3" ));
2、备注
(1)刚开始在网上找到了 两个例子,
https://blog.csdn.net/kongjiea/article/details/39644623
https://www.cnblogs.com/fishtreeyu/archive/2011/02/27/1966178.html
其使用的编码函数 均是 unescape。
此方法在IE浏览器运行正常,但是在火狐和谷歌浏览器下运行就会出错,中文解析会失败,导致中文字符乱码。
(2)解决的办法:将 unescape修改为 encodeURIComponent
如网上大神,
https://blog.csdn.net/unopenmycode/article/details/78835545
其对编码函数进行了修改,且对原因也进行了说明。
escape()不对“+”编码。但是我们知道,网页在提交表单的时候,如果有空格,则会被转化为+字符。服务器处理数据的时候,会把+号处理成空格。所以,使用的时候要小心。
encodeURIComponent()
最后一个Javascript编码函数是encodeURIComponent()。与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。
因此,“; / ? : @ & = + $ , #”,这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码。至于具体的编码方法,两者是一样。
encodeURIComponent()相比encodeURI()要更加彻底。
为什么优先使用encodeURIComponent而不是escape?
  escape方法并不编码字符+。而我们知道,在用户提交的表单字段中,如果有空格,则会被转化为+字符,而服务器解析的时候则会认为+号代表空格。由于这个缺陷,escape方法并不能正确地处理所有的非ASCII字符,你应当尽量避免使用escape方法,取而代之,你最好选择 encodeURIComponent()方法。

转载于:https://www.cnblogs.com/masonblog/p/9773876.html

你可能感兴趣的:(前台js获取url传递参数(后台Request.QueryString接收))