JavaScript对象之String
1. JavaScript 是面向对象的编程语言 (OOP)。
OOP 语言使我们有能力定义自己的对象和变量类型。对象只是一种特殊的数据。对象拥有属性和方法。
2. JavaScript字符串(String)对象
String对象属性
FF: Firefox, IE: Internet Explorer
| 属性 | 描述 | FF | IE |
| constructor | 对创建该对象的函数的引用 | 1 | 4 |
| 字符串的长度 | 1 | 3 | |
| prototype | 允许您向对象添加属性和方法 | 1 | 4 |
String对象方法
FF: Firefox, IE: Internet Explorer
| 方法 | 描述 | FF | IE |
| 创建 HTML锚。 | 1 | 3 | |
| 用大号字体显示字符串。 | 1 | 3 | |
| 显示闪动字符串。 | 1 |
| |
| 使用粗体显示字符串。 | 1 | 3 | |
| 返回在指定位置的字符。 | 1 | 3 | |
| 返回在指定的位置的字符的 Unicode编码。 | 1 | 4 | |
| 连接字符串。 | 1 | 4 | |
| 以打字机文本显示字符串。 | 1 | 3 | |
| 使用指定的颜色来显示字符串。 | 1 | 3 | |
| 使用指定的尺寸来显示字符串。 | 1 | 3 | |
| 从字符编码创建一个字符串。 | 1 | 4 | |
| 检索字符串。 | 1 | 3 | |
| 使用斜体显示字符串。 | 1 | 3 | |
| 从后向前搜索字符串。 | 1 | 3 | |
| 将字符串显示为链接。 | 1 | 3 | |
| 用本地特定的顺序来比较两个字符串。 | 1 | 4 | |
| 找到一个或多个正则表达式的匹配。 | 1 | 4 | |
| 替换与正则表达式匹配的子串。 | 1 | 4 | |
| 检索与正则表达式相匹配的值。 | 1 | 4 | |
| 提取字符串的片断,并在新的字符串中返回被提取的部分。 | 1 | 4 | |
| 使用小字号来显示字符串。 | 1 | 3 | |
| 把字符串分割为字符串数组。 | 1 | 4 | |
| 使用删除线来显示字符串。 | 1 | 3 | |
| 把字符串显示为下标。 | 1 | 3 | |
| 从起始索引号提取字符串中指定数目的字符。 | 1 | 4 | |
| 提取字符串中两个指定的索引号之间的字符。 | 1 | 3 | |
| 把字符串显示为上标。 | 1 | 3 | |
| 把字符串转换为小写。 | - | - | |
| 把字符串转换为大写。 | - | - | |
| 把字符串转换为小写。 | 1 | 3 | |
| 把字符串转换为大写。 | 1 | 3 | |
| toSource() | 代表对象的源代码。 | 1 | - |
| 返回字符串。 | - | - | |
| 返回某个字符串对象的原始值。 | 1 | 4 |
2.1 anchor举例:
<script type="text/javascript">
var txt="Hello world!"
document.write(txt.anchor("myanchor"))
</script>
结果:上面的代码将输出为纯粹的HTML:<a name="myanchor">Hello world!</a>
2.2 charAt()方法可返回指定位置的字符。
语法:stringObject.charAt(index);// index为字符串的下标
注释:字符串下标从0开始。如果参数index不在0与 string.length 之间,该方法将返回一个空字符串。
例子:
<script type="text/javascript">
var str="Hello world!"
document.write(str.charAt(1))
</script>
结果:以上代码的输出是:e
2.3 concat()方法用于连接两个或多个字符串。
语法:stringObject.concat(stringX,stringX,...,stringX)
请注意:使用" + "运算符来进行字符串的连接运算通常会更简便一些。
2.4 indexOf()方法可返回某个指定的字符串值在字符串中首次出现的位置。
语法:stringObject.indexOf(searchvalue,fromindex)
searchvalue必需。规定需检索的字符串值。
fromindex可选的整数参数。规定在字符串中开始检索的位置。它的合法取值是 0到 stringObject.length - 1。如省略该参数,则将从字符串的首字符开始检索。
如果要检索的字符串值没有出现,则该方法返回 -1。
2.5 lastIndexOf()方法可返回一个指定的字符串值最后出现的位置,在一个字符串中的指定位置从后向前搜索。
语法:stringObject.lastIndexOf(searchvalue,fromindex)
searchvalue必需。规定需检索的字符串值。
fromindex可选的整数参数。规定在字符串中开始检索的位置。它的合法取值是0到 stringObject.length - 1。如省略该参数,则将从字符串的最后一个字符处开始检索。
如果要检索的字符串值没有出现,则该方法返回 -1。
2.6 match()方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
该方法类似 indexOf()和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。如果没有匹配,返回null。
stringObject.match(searchvalue)
stringObject.match(regexp)
searchvalue必需。规定要检索的字符串值。
regexp必需。规定要匹配的模式的 RegExp对象。如果该参数不是 RegExp对象,则需要首先把它传递给 RegExp构造函数,将其转换为 RegExp对象。
返回值:存放匹配结果的数组。该数组的内容依赖于 regexp 是否具有全局标志 g。
说明
match()方法将检索字符串 stringObject,以找到一个或多个与 regexp 匹配的文本。这个方法的行为在很大程度上有赖于 regexp是否具有标志 g。
如果 regexp没有标志 g,那么 match() 方法就只能在 stringObject中执行一次匹配。如果没有找到任何匹配的文本, match()将返回null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。该数组的第 0 个元素存放的是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本。除了这些常规的数组元素之外,返回的数组还含有两个对象属性。index属性声明的是匹配文本的起始字符在 stringObject中的位置,input属性声明的是对 stringObject的引用。
如果 regexp具有标志 g,则 match() 方法将执行全局检索,找到 stringObject中的所有匹配子字符串。若没有找到任何匹配的子串,则返回null。如果找到了一个或多个匹配子串,则返回一个数组。不过全局匹配返回的数组的内容与前者大不相同,它的数组元素中存放的是 stringObject 中所有的匹配子串,而且也没有 index属性或 input属性。
注意:在全局检索模式下,match()即不提供与子表达式匹配的文本的信息,也不声明每个匹配子串的位置。如果您需要这些全局检索的信息,可以使用 RegExp.exec()。
例:使用全局匹配的正则表达式来检索字符串中的所有数字
<script type="text/javascript">
var str="1 plus 2 equal 3"
document.write(str.match(/\d+/g))
</script>
输出:1,2,3
2.7replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
语法:stringObject.replace(regexp/substr,replacement)
regexp/substr必需。规定子字符串或要替换的模式的 RegExp对象。
请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp对象。
replacement必需。一个字符串值。规定了替换文本或生成替换文本的函数。
返回值:一个新的字符串,是用 replacement替换了 regexp的第一次匹配或所有匹配之后得到的。
说明:
字符串 stringObject的 replace()方法执行的是查找并替换的操作。它将在 stringObject中查找与 regexp相匹配的子字符串,然后用 replacement来替换这些子串。如果 regexp具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。
replacement可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。但是 replacement中的 $字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。
例子:
<script type="text/javascript">
text ="javascrIpt Tutorial";
/* /javascript/i 是正则表达式,后面有个i表示对大小写不敏感 */
document.write(text.replace(/javascript/i,"JavaScript"));
</script>
相关:
创建一个正则表达式
第一种方法:var reg = /pattern/;
第二种方法:var reg =new RegExp('pattern');
2.8 search()方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。
语法:
stringObject.search(regexp)参数描述
regexp该参数可以是需要在 stringObject中检索的子串,也可以是需要检索的 RegExp对象。
注释:要执行忽略大小写的检索,请追加标志 i。
返回值:stringObject中第一个与 regexp 相匹配的子串的起始位置。如果没有找到任何匹配的子串,则返回-1。
说明:
search()方法不执行全局匹配,它将忽略标志g。它同时忽略regexp的lastIndex属性,并且总是从字符串的开始进行检索,这意味着它总是返回stringObject的第一个匹配的位置。
例子:以下结果输出-1
<script type="text/javascript">
var str="Visit W3School!"
document.write(str.search(/w3school/))
</script>
2.9 slice()方法可提取字符串的某个部分,并以新的字符串返回被提取的部分。
语法:stringObject.slice(start,end)
start必需。要抽取的片断的起始下标。如果是负数,则该参数规定的是从字符串的尾部开始算起的位置。也就是说,-1指字符串的最后一个字符,-2指倒数第二个字符,以此类推。
end可选。紧接着要抽取的片段的结尾的下标。若未指定此参数,则要提取的子串包括 start到原字符串结尾的字符串。如果该参数是负数,那么它规定的是从字符串的尾部开始算起的位置。
返回值:一个新的字符串。包括字符串 stringObject从 start开始(包括 start)到 end 结束(不包括 end)为止的所有字符。
说明
String对象的方法 slice()、substring()和 substr()(不建议使用)都可返回字符串的指定部分。slice()比 substring()要灵活一些,因为它允许使用负数作为参数。slice()与 substr()有所不同,因为它用两个字符的位置来指定子串,而 substr()则用字符位置和长度来指定子串。
还要注意的是,String.slice()与 Array.slice()相似。
2.10 substr()方法可在字符串中抽取从 start 下标开始的指定数目的字符。
语法
stringObject.substr(start,length)
start必需。要抽取的子串的起始下标。必须是数值。如果是负数,那么该参数声明从字符串的尾部开始算起的位置。也就是说,-1指字符串中最后一个字符,-2指倒数第二个字符,以此类推。
length可选。子串中的字符数。必须是数值。如果省略了该参数,那么返回从 stringObject的开始位置到结尾的字串。
返回值
一个新的字符串,包含从 stringObject的 start(包括 start 所指的字符)处开始的 lenght个字符。如果没有指定 lenght,那么返回的字符串包含从 start 到 stringObject的结尾的字符。
提示和注释
注释:substr() 的参数指定的是子串的开始位置和长度,因此它可以替代 substring()和 slice()来使用。
2.11 substring()用于提取字符串中介于两个指定下标之间的字符。
语法:stringObject.substring(start,stop)
start必需。一个非负的整数,规定要提取的子串的第一个字符在stringObject中的位置。
stop可选。一个非负的整数,比要提取的子串的最后一个字符在stringObject中的位置多1。
如果省略该参数,那么返回的子串会一直到字符串的结尾。
返回值:
一个新的字符串,该字符串值包含stringObject的一个子字符串,其内容是从 start 处到 stop-1处的所有字符,其长度为 stop减 start。
说明:
substring()方法返回的子串包括 start处的字符,但不包括 end处的字符。
如果参数start与end相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。如果start比end大,那么该方法在提取子串之前会先交换这两个参数。
与slice()和substr()方法不同的是,substring()不接受负的参数。
本文深入探讨了JavaScript作为面向对象编程语言的特点,重点讲解了如何使用JavaScript字符串对象,包括其属性、方法及其应用实例。
4624

被折叠的 条评论
为什么被折叠?



