百度“js  正则表达式  定位符”,多是如下内容:

 

除了我们以上所介绍的元字符之外,正则表达式中还具有另外一种较为独特的专用字符,即定位符。定位符用于规定匹配模式在目标对象中的出现位置。 较为常用的定位符包括: “^”, “$”, “A word boundary is the position between a word and a space.” 以及 “\B”。

“^”定位符规定匹配模式必须出现在目标字符串的开头

  “$”定位符规定匹配模式必须出现在目标对象的结尾

“\b”定位符规定匹配模式必须出现在目标字符串的开头或结尾的两个边界之一

  “\B”定位符则规定匹配对象必须位于目标字符串的开头和结尾两个边界之内,

  即匹配对象既不能作为目标字符串的开头,也不能作为目标字符串的结尾。

  同样,我们也可以把“^”和“$”以及“\b”和“\B”看作是互为逆运算的两组定位符。举例来说: /^hell/ 因为上述正则表达式中包含“^”定位符,所以可以与目标对象中以 “hell”, “hello”或“hellhound”开头的字符串相匹配。 /ar$/ 因为上述正则表达式中包含“$”定位符,所以可以与目标对象中以 “car”, “bar”或 “ar” 结尾的字符串相匹配。 /\bbom/ 因为上述正则表达式模式以“\b”定位符开头,所以可以与目标对象中以 “bomb”, 或 “bom”开头的字符串相匹配。/man\b/ 因为上述正则表达式模式以“\b”定位符结尾,所以可以与目标对象中以 “human”, “woman”或 “man”结尾的字符串相匹配。

 

“^”,和“\b” 所作用的对象都被解释成目标字符串,其实这有歧义

 

如http://www.w3school.com.cn/tiy/t.asp?f=jseg_replace_6

对于如下js代码:

“
name = 'aaa bbb ccc';
uw=name.replace(/\b\w+\b/g, function(word){
    return word.substring(0,1).toUpperCase()+word.substring(1);}
    );
“

结果是 Aaa Bbb Ccc

 

但如果把/\b\w+\b/g 换成 /^\w+\b/g

则结果是 Aaa bbb ccc

 

查看英文解释:

\b :  A word boundary,A word boundary is the position between a word and a space.

 

^ $ :Using both the ^ and the $ indicates that the specified pattern must encompass the
entire candidate string. For example: /^test$/.

 

很显然,\b 作用的对象是字符串中的单词  ,而^的作用对象时整个字符串

 

^-^ !