您的位置:首页 > Web前端 > JavaScript

常用的 JavaScript String 对象 indexOf() substring() split() replace()

2013-05-31 10:11 453 查看

JavaScriptindexOf()方法

定义和用法

indexOf()方法可返回某个指定的字符串值在字符串中首次出现的位置。语法
stringObject.indexOf(searchvalue,fromindex)

参数
描述
searchvalue
必需。规定需检索的字符串值。
fromindex
可选的整数参数。规定在字符串中开始检索的位置。它的合法取值是0到stringObject.length-1。如省略该参数,则将从字符串的首字符开始检索。
说明
该方法将从头到尾地检索字符串stringObject,看它是否含有子串searchvalue。开始检索的位置在字符串的fromindex处或字符串的开头(没有指定fromindex时)。如果找到一个searchvalue,则返回searchvalue的第一次出现的位置。stringObject中的字符位置是从0开始的。

提示和注释

注释:indexOf()方法对大小写敏感!
注释:如果要检索的字符串值没有出现,则该方法返回-1。

实例

在本例中,我们将在"Helloworld!"字符串内进行不同的检索:
<scripttype="text/javascript">

varstr="Helloworld!"
document.write(str.indexOf("Hello")+"<br/>")
document.write(str.indexOf("World")+"<br/>")
document.write(str.indexOf("world"))

</script>

以上代码的输出:
0
-1
6
=========================

JavaScriptsubstring()方法

定义和用法

substring()方法用于提取字符串中介于两个指定下标之间的字符。
语法
stringObject.substring(start,stop)

参数
描述
start
必需。一个非负的整数,规定要提取的子串的第一个字符在stringObject中的位置。
stop
可选。一个非负的整数,比要提取的子串的最后一个字符在stringObject中的位置多1。
如果省略该参数,那么返回的子串会一直到字符串的结尾。
返回值
一个新的字符串,该字符串值包含stringObject的一个子字符串,其内容是从start处到stop-1处的所有字符,其长度为stopstart
说明
substring()方法返回的子串包括start处的字符,但不包括stop处的字符。
如果参数startstop相等,那么该方法返回的就是一个空串(即长度为0的字符串)。如果startstop大,那么该方法在提取子串之前会先交换这两个参数。

提示和注释

重要事项:与slice()和substr()方法不同的是,substring()不接受负的参数。

实例

例子1
在本例中,我们将使用substring()从字符串中提取一些字符:
<scripttype="text/javascript">

varstr="Helloworld!"
document.write([code]str.substring(3)
)

</script>[/code]
输出:
loworld!

例子2
在本例中,我们将使用substring()从字符串中提取一些字符:
<scripttype="text/javascript">

varstr="Helloworld!"
document.write([code]str.substring(3,7)
)

</script>[/code]
输出:
low
========================

JavaScriptsplit()方法

定义和用法

split()方法用于把一个字符串分割成字符串数组。
语法
stringObject.split(separator,howmany)

参数
描述
separator
必需。字符串或正则表达式,从该参数指定的地方分割stringObject。
howmany
可选。该参数可指定返回的数组的最大长度。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。
返回值
一个字符串数组。该数组是通过在separator指定的边界处将字符串stringObject分割成子串创建的。返回的数组中的字串不包括separator自身。
但是,如果separator是包含子表达式的正则表达式,那么返回的数组中包括与这些子表达式匹配的字串(但不包括与整个正则表达式匹配的文本)。

提示和注释

注释:如果把空字符串("")用作separator,那么stringObject中的每个字符之间都会被分割。
注释:String.split()执行的操作与Array.join执行的操作是相反的。

实例

例子1
在本例中,我们将按照不同的方式来分割字符串:
<scripttype="text/javascript">

varstr="Howareyoudoingtoday?"

document.write(str.split("")+"<br/>")
document.write(str.split("")+"<br/>")
document.write(str.split("",3))

</script>

输出:
How,are,you,doing,today?
H,o,w,,a,r,e,,y,o,u,,d,o,i,n,g,,t,o,d,a,y,?
How,are,you

例子2
在本例中,我们将分割结构更为复杂的字符串:
"2:3:4:5".split(":")	//将返回["2","3","4","5"]
"|a|b|c".split("|") //将返回["","a","b","c"]

例子3
使用下面的代码,可以把句子分割成单词:
varwords=sentence.split('')

或者使用正则表达式作为separator:
varwords=sentence.split(/\s+/)

例子4
如果您希望把单词分割为字母,或者把字符串分割为字符,可使用下面的代码:
"hello".split("")	//可返回["h","e","l","l","o"]

若只需要返回一部分字符,请使用howmany参数:
"hello".split("",3)	//可返回["h","e","l"]
===============================

JavaScriptreplace()方法

定义和用法

replace()方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
语法
stringObject.replace(regexp/substr,replacement)

参数
描述
regexp/substr
必需。规定子字符串或要替换的模式的RegExp对象。
请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为RegExp对象。
replacement
必需。一个字符串值。规定了替换文本或生成替换文本的函数。
返回值
一个新的字符串,是用replacement替换了regexp的第一次匹配或所有匹配之后得到的。
说明
字符串stringObject的replace()方法执行的是查找并替换的操作。它将在stringObject中查找与regexp相匹配的子字符串,然后用replacement来替换这些子串。如果regexp具有全局标志g,那么replace()方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。
replacement可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。但是replacement中的$字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。
字符
替换文本
$1、$2、...、$99
与regexp中的第1到第99个子表达式相匹配的文本。
$&
与regexp相匹配的子串。
$`
位于匹配子串左侧的文本。
$'
位于匹配子串右侧的文本。
$$
直接量符号。
注意:ECMAScriptv3规定,replace()方法的参数replacement可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用。该函数的第一个参数是匹配模式的字符串。接下来的参数是与模式中的子表达式匹配的字符串,可以有0个或多个这样的参数。接下来的参数是一个整数,声明了匹配在stringObject中出现的位置。最后一个参数是stringObject本身。

实例

例子1
在本例中,我们将使用"W3School"替换字符串中的"Microsoft":
<scripttype="text/javascript">

varstr="VisitMicrosoft!"
document.write([code]str.replace(/Microsoft/,"W3School")
)

</script>[/code]
输出:
VisitW3School!

例子2
在本例中,我们将执行一次全局替换,每当"Microsoft"被找到,它就被替换为"W3School":
<scripttype="text/javascript">

varstr="WelcometoMicrosoft!"
str=str+"WeareproudtoannouncethatMicrosofthas"
str=str+"oneofthelargestWebDeveloperssitesintheworld."

document.write([code]str.replace(/Microsoft/g,"W3School")
)

</script>[/code]
输出:
WelcometoW3School!WeareproudtoannouncethatW3School
hasoneofthelargestWebDeveloperssitesintheworld.

例子3
您可以使用本例提供的代码来确保匹配字符串大写字符的正确:
text="javascriptTutorial";
text.replace(/javascript/i,"JavaScript");

例子4
在本例中,我们将把"Doe,John"转换为"JohnDoe"的形式:
name="Doe,John";
name.replace(/(\w+)\s*,\s*(\w+)/,"$2$1");

例子5
在本例中,我们将把所有的花引号替换为直引号:
name='"a","b"';
name.replace(/"([^"]*)"/g,"'$1'");

例子6
在本例中,我们将把字符串中所有单词的首字母都转换为大写:
name='aaabbbccc';
uw=name.replace(/\b\w+\b/g,function(word){
returnword.substring(0,1).toUpperCase()+word.substring(1);}
);

TIY

replace()1
如何使用replace()来替换字符串中的字符。
replace()2-全局搜索
如何使用replace()进行全局替换。
replace()3-对大小写不敏感的搜索
如何使用replace()确保大写字母的正确性。
replace()4
如何使用replace()来转换姓名的格式。
replace()5
如何使用replace()来转换引号。
replace()6
如何使用replace()把单词的首字母转换为大写。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐