Code:
var match1 = new RegExp('\S*//weibo\.com/p/\S*');
var match2 = new RegExp('\S*//weibo\.com/p/\S+');
match1.test('http://weibo.com/p/12345/myfollow?relate=fans#place');//true
match2.test('http://weibo.com/p/12345/myfollow?relate=fans#place');//false
Ich bin ein wenig verwirrt, warum Match2 falsch ist und was zum Teufel stimmt mit Match1 überein?
大兄弟,你的正则表达式写的有问题,首先正则表达式的构造有两种形式,一种是你这样,另一种是
/abc/g
。看你的意思,你的正则表达式应该这样写:
你的少了反斜杠,转义失败
为什么?因为按照你的正则表达式,实际上:
然后就是
*
和+
的区别了,所以第一个为 true,第二个为 false。建议构造正则表达式的时候用两个斜杠,这样可以不用转义:
match1:s匹配0个多1个或多个空格,//这个的话最好转义一下使用//这样匹配的才是'/',.这个匹配的是'.',如果没有反斜杠是匹配任意字符,最后一个s匹配0个多1个或多个空格。
match2:只有最后一个不一样,s+,一个或多个空格,但是你的字符串明显在p之后没有空格所以false