w3cshool之JavaScript对象_String

本文深入探讨了JavaScript作为面向对象编程语言的特点,重点讲解了如何使用JavaScript字符串对象,包括其属性、方法及其应用实例。

JavaScript对象之String

1. JavaScript 是面向对象的编程语言 (OOP)。

OOP 语言使我们有能力定义自己的对象和变量类型。对象只是一种特殊的数据。对象拥有属性和方法。

2. JavaScript字符串(String)对象

String对象属性

FF: Firefox, IE: Internet Explorer

属性

描述

FF

IE

constructor

对创建该对象的函数的引用

1

4

length

字符串的长度

1

3

prototype

允许您向对象添加属性和方法

1

4

String对象方法

FF: Firefox, IE: Internet Explorer

方法

描述

FF

IE

anchor()

创建 HTML锚。

1

3

big()

用大号字体显示字符串。

1

3

blink()

显示闪动字符串。

1

 

bold()

使用粗体显示字符串。

1

3

charAt()

返回在指定位置的字符。

1

3

charCodeAt()

返回在指定的位置的字符的 Unicode编码。

1

4

concat()

连接字符串。

1

4

fixed()

以打字机文本显示字符串。

1

3

fontcolor()

使用指定的颜色来显示字符串。

1

3

fontsize()

使用指定的尺寸来显示字符串。

1

3

fromCharCode()

从字符编码创建一个字符串。

1

4

indexOf()

检索字符串。

1

3

italics()

使用斜体显示字符串。

1

3

lastIndexOf()

从后向前搜索字符串。

1

3

link()

将字符串显示为链接。

1

3

localeCompare()

用本地特定的顺序来比较两个字符串。

1

4

match()

找到一个或多个正则表达式的匹配。

1

4

replace()

替换与正则表达式匹配的子串。

1

4

search()

检索与正则表达式相匹配的值。

1

4

slice()

提取字符串的片断,并在新的字符串中返回被提取的部分。

1

4

small()

使用小字号来显示字符串。

1

3

split()

把字符串分割为字符串数组。

1

4

strike()

使用删除线来显示字符串。

1

3

sub()

把字符串显示为下标。

1

3

substr()

从起始索引号提取字符串中指定数目的字符。

1

4

substring()

提取字符串中两个指定的索引号之间的字符。

1

3

sup()

把字符串显示为上标。

1

3

toLocaleLowerCase()

把字符串转换为小写。

-

-

toLocaleUpperCase()

把字符串转换为大写。

-

-

toLowerCase()

把字符串转换为小写。

1

3

toUpperCase()

把字符串转换为大写。

1

3

toSource()

代表对象的源代码。

1

-

toString()

返回字符串。

-

-

valueOf()

返回某个字符串对象的原始值。

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。它同时忽略regexplastIndex属性,并且总是从字符串的开始进行检索,这意味着它总是返回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处的字符。

如果参数startend相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。如果startend大,那么该方法在提取子串之前会先交换这两个参数。

slice()substr()方法不同的是,substring()不接受负的参数。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值