javascript中字符串常用操作总结
Posted 黑皮
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript中字符串常用操作总结相关的知识,希望对你有一定的参考价值。
String对象属性
(1) length属性
length算是字符串中非常常用的一个属性了,它的功能是获取字符串的长度。当然需要注意的是js中的中文每个汉字也只代表一个字符,这里可能跟其他语言有些不一样。
var str = ‘abc‘; console.log(str.length);
(2) prototype属性
prototype在面向对象编程中会经常用到,用来给对象添加属性或方法,并且添加的方法或属性在所有的实例上共享。因此也常用来扩展js内置对象,如下面的代码给字符串添加了一个去除两边空格的方法:
String.prototype.trim = function(){ return this.replace(/^\s*|\s*$/g, ‘‘); }
String对象方法
1.获取类方法
(1) charAt()
stringObject.charAt(index)
charAt()方法可用来获取指定位置的字符串,index为字符串索引值,从0开始到string.leng – 1,若不在这个范围将返回一个空字符串。如:
var str = ‘abcde‘; console.log(str.charAt(2)); //返回c console.log(str.charAt(8)); //返回空字符串
(2) charCodeAt()
stringObject.charCodeAt(index)
charCodeAt()方法可返回指定位置的字符的Unicode编码。charCodeAt()方法与charAt()方法类似,都需要传入一个索引值作为参数,区别是前者返回指定位置的字符的编码,而后者返回的是字符子串。
var str = ‘abcde‘; console.log(str.charCodeAt(0)); //返回97
(3) fromCharCode()
String.fromCharCode(numX,numX,…,numX)
fromCharCode()可接受一个或多个Unicode值,然后返回一个字符串。另外该方法是String 的静态方法,字符串中的每个字符都由单独的数字Unicode编码指定。
String.fromCharCode(97, 98, 99, 100, 101) //返回abcde
2.查找类方法
(1) indexOf()
stringObject.indexOf(searchvalue,fromindex)
indexOf()用来检索指定的字符串值在字符串中首次出现的位置。它可以接收两个参数,searchvalue表示要查找的子字符串,fromindex表示查找的开始位置,省略的话则从开始位置进行检索。
var str = ‘abcdeabcde‘; console.log(str.indexOf(‘a‘)); // 返回0 console.log(str.indexOf(‘a‘, 3)); // 返回5 console.log(str.indexOf(‘bc‘)); // 返回1
(2) lastIndexOf()方法
stringObject.lastIndexOf(searchvalue,fromindex)
lastIndexOf()语法与indexOf()类似,它返回的是一个指定的子字符串值最后出现的位置,其检索顺序是从后向前。
var str = ‘abcdeabcde‘; console.log(str.lastIndexOf(‘a‘)); // 返回5 console.log(str.lastIndexOf(‘a‘, 3)); // 返回0 从第索引3的位置往前检索 console.log(str.lastIndexOf(‘bc‘)); // 返回6
(3) search()方法
stringObject.search(substr)
stringObject.search(regexp)
search()方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。它会返回第一个匹配的子字符串的起始位置,如果没有匹配的,则返回-1。
var str = ‘abcDEF‘; console.log(str.search(‘c‘)); //返回2 console.log(str.search(‘d‘)); //返回-1 console.log(str.search(/d/i)); //返回3
(4) match()方法
stringObject.match(substr)
stringObject.match(regexp)
match()方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
如果参数中传入的是子字符串或是没有进行全局匹配的正则表达式,那么match()方法会从开始位置执行一次匹配,如果没有匹配到结果,则返回null。否则则会返回一个数组,该数组的第0个元素存放的是匹配文本,除此之外,返回的数组还含有两个对象属性index和input,分别表示匹配文本的起始字符索引和stringObject 的引用(即原字符串)。
var str = ‘1a2b3c4d5e‘; console.log(str.match(‘h‘)); //返回null console.log(str.match(‘b‘)); //返回["b", index: 3, input: "1a2b3c4d5e"] console.log(str.match(/b/)); //返回["b", index: 3, input: "1a2b3c4d5e"]
如果参数传入的是具有全局匹配的正则表达式,那么match()从开始位置进行多次匹配,直到最后。如果没有匹配到结果,则返回null。否则则会返回一个数组,数组中存放所有符合要求的子字符串,并且没有index和input属性。
var str = ‘1a2b3c4d5e‘; console.log(str.match(/h/g)); //返回null console.log(str.match(/\d/g)); //返回["1", "2", "3", "4", "5"]
3.截取类方法
(1) substring()
以上是关于javascript中字符串常用操作总结的主要内容,如果未能解决你的问题,请参考以下文章