这个正则 var reg = /([^?&=]+)=([^?&=]*)/g;啥意思?

  var reg = /([^?&=]+)=([^?&=]*)/g;
阅读 7.3k
3 个回答

"http:/www.baidu.com/?a=1&b=2".match(/([^?&=]+)=([^?&=]*)/g); //["a=1", "b=2"]

前后的斜杠/是正则表达式的分隔符,最后的g表示全局匹配,匹配到第一个之后不会停下来,会继续匹配,相当于PHP里的preg_match_all,没有g就相当于preg_match,下面有例子说明.

()表示子组.

[^]表示字符类取反,比如[^abc]匹配的就是不是a和b和c的单个字符,[^?&=]匹配不是^和?和=的单个字符.

字符类[]后面的+*表示量词:
+ 等价于 {1,} 重复1次或多次
* 等价于 {0,} 重复0次或多次

var str = "foo=bar&lang=js";
var reg = /[^?&=]{1,}=[^?&=]{0,}/g;
console.log(str.match(reg)); //输出 ["foo=bar", "lang=js"]

var str = "foo=bar&lang=js";
var reg = /[^?&=]{1,}=[^?&=]{0,}/;
console.log(str.match(reg)); //输出 ["foo=bar"]

var str = "foo=bar&lang=js";
var reg = /([^?&=]{1,})=([^?&=]{0,})/;
console.log(str.match(reg)); //输出 ["foo=bar", "foo", "bar"]

这段规则式一般用于提取URL中的参数,会把URL中?后的参数部分以&分割为参数对,比如

"http:/www.baidu.com/?a=1&b=2".match(/([^?&=]+)=([^?&=]*)/g); 

匹配的结果就是

["a=1", "b=2"]
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题