12JavaScript字符串
javascript 字符串用于存储和处理文本。
1.javascript 字符串
字符串可以存储一系列字符,如 "john doe"。
字符串可以是插入到引号中的任何字符。你可以使用单引号或双引号:
实例:
var carname = "volvo xc60"; var carname = 'volvo xc60';
你可以使用索引位置来访问字符串中的每个字符:
var character = carname[7];
字符串的索引从 0 开始,这意味着第一个字符索引值为 [0],第二个为 [1], 以此类推。
你可以在字符串中使用引号,字符串中的引号不要与字符串的引号相同:
var answer = "it's alright"; var answer = "he is called 'johnny'"; var answer = 'he is called "johnny"';
我们也可以在字符串添加转义字符来使用引号:
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>yubaba</title> 6 </head> 7 <body> 8 9 <p id="demo"></p> 10 <script> 11 var x = 'it\'s alright'; 12 var y = "he is called \"johnny\""; 13 document.getelementbyid("demo").innerhtml = x + "<br>" + y; 14 </script> 15 16 </body> 17 </html>
运行结果:
2.字符串长度
可以使用内置属性 length 来计算字符串的长度
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>yubaba</title> 6 </head> 7 <body> 8 9 <script> 10 var txt = "hello world!"; 11 document.write( txt.length + "<br>"); 12 var txt="abcdefghijklmnopqrstuvwxyz"; 13 document.write(txt.length +"<br>"); 14 </script> 15 16 </body> 17 </html> 18 19 //输出结果: 20 21 12 22 26
3.特殊字符
在 javascript 中,字符串写在单引号或双引号中。
因为这样,以下实例 javascript 无法解析:
"we are the so-called "vikings" from the north."
上面的字符串 "we are the so-called " 被截断
如何解决以上的问题呢?可以使用反斜杠 (\) 来转义 "vikings" 字符串中的双引号,如下:
"we are the so-called \"vikings\" from the north."
反斜杠是一个转义字符。 转义字符将特殊字符转换为字符串字符:
转义字符 (\) 可以用于转义撇号,换行,引号,等其他特殊字符。
下表中列举了在字符串中可以使用转义字符转义的特殊字符:
代码 | 输出 |
---|---|
\' | 单引号 |
\" | 双引号 |
\\ | 反斜杠 |
\n | 换行 |
\r | 回车 |
\t | tab(制表符) |
\b | 退格符 |
\f | 换页符 |
4.字符串可以是对象
通常, javascript 字符串是原始值,可以使用字符创建: var firstname = "john"
但我们也可以使用 new 关键字将字符串定义为一个对象: var firstname = new string("john")
实例:
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>yubaba</title> 6 </head> 7 <body> 8 9 <p id="demo"></p> 10 <script> 11 var x = "john"; // x是一个字符串 12 var y = new string("john"); // y是一个对象 13 document.getelementbyid("demo").innerhtml ="x类型为"+typeof x + " , " +"y类型为"+ typeof y; 14 </script> 15 16 </body> 17 </html>
运行结果:
不要创建 string 对象。它会拖慢执行速度,并可能产生其他副作用:
实例:
1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>yubaba</title> 6 </head> 7 <body> 8 <p>x===y吗?</p> 9 <p id="demo"></p> 10 <script> 11 var x = "john"; // x 是字符串 12 var y = new string("john"); // y 是一个对象 13 document.getelementbyid("demo").innerhtml =x===y; 14 </script> 15 <p>=== 为绝对相等,即数据类型与值都必须相等。</p> 16 17 </body> 18 </html>
运行结果:
5.字符串属性和方法
原始值字符串,如 "john", 没有属性和方法(因为他们不是对象)。
原始值可以使用 javascript 的属性和方法,因为 javascript 在执行方法和属性时可以把原始值当作对象。
字符串属性
属性 | 描述 |
---|---|
constructor | 返回创建字符串属性的函数 |
length | 返回字符串的长度 |
prototype | 允许您向对象添加属性和方法 |
字符串方法
更多方法实例可以参见:javascript string 对象。
方法 | 描述 |
---|---|
charat() | 返回指定索引位置的字符 |
charcodeat() | 返回指定索引位置字符的 unicode 值 |
concat() | 连接两个或多个字符串,返回连接后的字符串 |
fromcharcode() | 将 unicode 转换为字符串 |
indexof() | 返回字符串中检索指定字符第一次出现的位置 |
lastindexof() | 返回字符串中检索指定字符最后一次出现的位置 |
localecompare() | 用本地特定的顺序来比较两个字符串 |
match() | 找到一个或多个正则表达式的匹配 |
replace() | 替换与正则表达式匹配的子串 |
search() | 检索与正则表达式相匹配的值 |
slice() | 提取字符串的片断,并在新的字符串中返回被提取的部分 |
split() | 把字符串分割为子字符串数组 |
substr() | 从起始索引号提取字符串中指定数目的字符 |
substring() | 提取字符串中两个指定的索引号之间的字符 |
tolocalelowercase() | 根据主机的语言环境把字符串转换为小写,只有几种语言(如土耳其语)具有地方特有的大小写映射 |
tolocaleuppercase() | 根据主机的语言环境把字符串转换为大写,只有几种语言(如土耳其语)具有地方特有的大小写映射 |
tolowercase() | 把字符串转换为小写 |
tostring() | 返回字符串对象值 |
touppercase() | 把字符串转换为大写 |
trim() | 移除字符串首尾空白 |
valueof() | 返回某个字符串对象的原始值 |
上一篇: 要不要这么用功
下一篇: OOP_由C到C++