var
pattern=/\w{2,3}/
console.log("aaaa".match(pattern)[0])
/*结果"aaa"贪婪模式下会尽可能多的匹配,
所以会匹配3个重复的字符
*/
var
pattern2=/\w{2,3}?/
console.log("aaaa".match(pattern2)[0])
/*
*结果"aa"加问号后会尽可能少的匹配重复次数,
*所以匹配到了2个重复的字符
*/
在分组内使用?:可以产生没有编号的分组,比如
var
pattern=/(ab)\w+(ba)/
console.log("abcba_".replace(pattern,"$1"))
/*结果"ab_"匹配到的字符被第一个分组(ab)
*替换
*/
var
pattern2=/(?:ab)\w+(ba)/
console.log("abcba_".replace(pattern2,"$1"))
/*
*结果"ba_"第一次分组内加入了?:,产生的是一个
*没有编号的分组,所以$1匹配的字符是第二个分组,
*也就是第一个编号分组(ba)相匹配的文本内容
*/
(?=)和(?!)零宽正向断言和负向断言,括号内表示某个位置右边必须和=右边匹配上,或者不和!后的字符匹配。
var
pattern=/str(?=ings)ing/
console.log("strings.a".match(pattern))
console.log("strings.a".match(/string(?=s)/))
console.log("string_x".match(pattern))
console.log("string_x".match(/string(?=s)/))
/*前两个结果是["string"],后两个结果是null
*str(?=ings)ing/匹配"string",r后面的位置右边必须跟
*上ings和/string(?=s)/一样匹配"string"g后面的位置
*的右边必须跟一个s。"string_x"虽然也含有"string"但是
*不满足(?=...)括号内的条件
*/
var
pattern=/string(?!s)/
console.log("strings".match(pattern))//null
console.log("string.".match(pattern))//["string"]
/*(?!...)某位置右边不能有!后匹配的字符,
*string(?!s)/匹配"string","g"后不能跟"s"
*/
在表示重复次数时,代表重复0次或1次
问号是网址(标准叫法是url)中主体部分(文件路径)与参数部分的分割符,一般用于给动态网页传递参数。css和js链接地址中带的问号,作用则主要是为了“骗”浏览器的。我们都知道,浏览器肯定都有缓存文件的,当再次访问一个相同的网址时(包括htm、css、js以及各种图片),浏览器会首先去提取缓存文件,尤其是手机上的浏览器,由于涉及流量(每一秒都是钱啊),所以缓存文件的优先级更高,网站上的文件发生变化后,手机上可能过很久都仍然是更新前的页面(有的甚至要过24小时才会生效)。这种做法,虽然可以节省手机流量,但是对于网站的开发者来说就会造成困扰了,因为网页做了修改(比如图片改了,但文件名不变),却无法立即反映到用户的设备上。这时候就可以在网址(htm文件以及文件中包含的各种资源)中加个问号,后面再加个随机的数字(或者字符),这样浏览器就会认为这是个不同的网址,就会跳过缓存直接去网站提取,这样用户的手机上就会立刻出现更新后的网页或者资源(如css、js以及图片)了。