谁说正则表达式就是尽量向后替换的?^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的  
Multiline 属性,^ 也匹配 'n' 或 'r' 之后的位置。   $ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的   
Multiline 属性,$ 也匹配 'n' 或 'r' 之前的位置。   * 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z"  
以及"zoo"。 * 等价于{0,}。   + 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo"   
以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。   ? 匹配前面的子表达式零次或一次。例如,"do(es)?" 可以  
匹配"do" 或 "does" 中的"do" 。? 等价于 {0,1}。   {n} n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不  
能匹配"Bob" 中的 'o',但是能匹配 "food" 中的两个 o。   {n,} n 是一个非负整数。至少匹配n 次。例如,'o{2,}' 不能匹配   
"Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}'   
等价于 'o+'。'o{0,}' 则等价于 'o*'。   {n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹  
配 m 次。刘, "o{1,3}" 将匹配 "fooooood" 中的前三个o。  
'o{0,1}'等价于'o?'。请注意在逗号和两个数之间不能有空格  ? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,},  
{n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的   
匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜  
索的字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个   
"o",而 'o+' 将匹配所有 'o'。  . 匹配除 "n" 之外的任何单个字符。要匹配包括 'n' 在内的任  
何字符,请使用象 '[.n]' 的模式。