匹配页面传过来的参数的代码如下:
function getQueryString(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;
}
对代码的解释:
类似浏览器地址栏地址参数部分格式的正则匹配
var
reg =
new
RegExp(
"(^|&)"
+ name +
"=([^&]*)(&|$)"
,
"i"
);
<==> name=abc&pp=cde&...
或者 &name=abc&pp=cde&...
匹配这样的类似参数,但是他只取name参数部分
name=abc 或 &name=abc
window.location.search 部分是 ?name=dddcdsdfs 的类似
取第一个索引开始就是:name=dddcdsdfs来匹配正则
如果不是
null
,匹配到了
然后再通过找到形式为 %xx 和 %uxxxx 的字符序列(x 表示十六进制的数字),用 Unicode 字符 \u00xx 和 \uxxxx 替换这样的字符序列进行解码。
是对r[2]解码,就是对name的值dddcdsdfs进行解码.
返回被解码的name的值。
至于:
"=([^&]*)(&|$)"
的意思就是 匹配name=abcd 到 (下一个&的开始到最后一个&结尾)之前的部分 就是name=abcd或&name=abcd这一段.所以name里面或许有存在&