javascript从字符串中查找子字符串的方法:indexOf()和lastIndexOf()。
它们均是从一个字符串中搜索给定的字符串,然后返回子字符串的位置(如果没有子字符串的位置,则返回-1)。
区别在于:indexOf()方法从字符串的开头向后搜索字符串,而lastIndexOf()方法是从字符串的末尾向前搜索子字符串。
子字符串“o”第一次出现的位置是4,即“hello”中的“o”;最后一次出现的位置是7,即“world”中的“o”。如果“o”在这个字符串中只出现了一次,那么indexOf()和lastIndexOf()会返回相同的位置值。
两个方法都可以接受可选的第二个参数,表示从字符串中的哪个位置开始搜索。
即,indexOf()会从该参数指定的位置向后搜索,忽略该位置之前的所有字符;
而lastIndexOf()则会从指定的位置向前搜索,忽略该位置之后的所有字符。
例子:
在将第二个参数6传递给这两个方法之后,得到了与前面例子相反的结果。这一次,由于indexOf()是从位置6(字母“w”)开始向后搜索,结果在位置7找到了“o”,因此它返回7。而lastIndexOf()是从6开始向前搜索,结果找到了“hello”中的“o”,因此它返回4。在使用第二个参数的情况下,可以通过循环调用indexOf()或lastIndexOf()来找到所有匹配的子字符串。
例子:
var stringValue = "Lorem ipsum dolor sit amet, consectetur adipisicing elit";
var positions = new Array();
var pos = stringValue.indexOf("e");
while (pos > -1) {
positions.push(pos);
pos = stringValue.indexOf("e", pos + 1);
}
alert(positions); //"3,24,32,35,52"
代码说明:
不断增加indexOf()方法开始查找的位置,遍历了一个长字符串。
在循环之外,首先找到了“e”在字符串中的初始位置;
而进入循环后,则每次都给indexOf()传递上一次的位置加1。
这样,就确保了每次新搜索都从上一次找到字符串的后面开始。
每次搜索返回的位置一次被保存在数组positions中,以便将来使用。