javascript中很经常的会用到string类型的变量,对此,总结了几种常用操作或者方法:创建、拼接、子串、大小写转换、判断字符串相等、字符串查找等几种。下面将一一简单描述。
一、js中string的创建。
创建string变量可以说有两种:
一种是最基本的直接声明然后初始化的情况,用引号将一组字符包含起来,这里的引号可以是一对单引号也可以是一对双引号,但是不能是一个单引号和一个双引号组合的形式,即下面的是不正确的。
1 var myString = "Fluffy is a pretty cat.';
另一种是用新建对象的形式新建string对象。举例:
1 var str1 = "Hello world!"; 2 var str2 = new String("I love you!");
这两种方式都可以新建str变量,但是这两种方式还是不同的,第一种是建立了一个字符串类型的值,而第二种是建立了字符串类型的对象。用typeof运算符可看出,第一种是string,而第二种是Object。
如果想知道字符串长度可以通过length的方式获得,即str1.length。如果想得到字符串指定位置的字符可通过charAt的方式获取。
二、字符串拼接。
字符串拼接是指将两个字符串放到一块组成一个大的新的字符串,拼接也有两种简单方式:
一种是简单地用“+”进行拼接,
1 var str = "hello," + " world!";
如果有多个进行拼接,可以使用“+=”进行拼接。
1 var result = ""; 2 result += "My name is Anders" 3 result += " and my age is 25";
String对象还提供了方法concat(),它完成与"+"相同的功能:
1 string.concat(value1, value2, ...)
不过concat()方法显然不如"+"来得直观简洁。
三、访问子串
这里的访问子串的意思就是获取字符串的一部分文本,同样有两种方法,一种是substring(),一种是slice();
substring的用法是string.substring(from,to),根据参数就可以看出其具体用法,返回的是从from开始(包括from位置)到end结束(不包括end)中的字符串,from指明了子字符串在原字符串中起始位置,这里要注意是基于0索引的,to是可选的,它指明了子字符串的结束位置,同样是基于0索引的,如果被忽略,则结束位置默认为原字符串的结束。
一般情况下他应该比from的值大,否则,系统将自动调整两者的大小,将小的值作为起始位置,大的值作为结束位置。
举例如下:
1 var fullString = "Every dog has his day."; 2 var section = fullString.substring(0, 4); // section is "Ever". 3 section = fullString.substring(4, 0); // section is also "Ever". 4 section = fullString.substring(1, 1); // section is an empty string. 5 section = fullString.substring(-2, 4); // section is "Ever", same as fullString.substring(0, 4);
对于slice()函数,用法是string.slice(start,end);同样可以通过参数看出具体用法,参数start表示子串的起始位置,如果为负数,那么可以理解为倒数第几个开始,end也可以这么处理。例如-3表示从倒数第三个开始;slice()的参数可以为负数,所以要比substring()更加灵活,但没那么宽容了,如果start比end要大,它将返回一个空字符串(示例略)。
其实还有一个方法,substr(start,length),但是JavaScript标准不提倡使用该方法。
四、大小写的转换
有些文本框接受输入,然后去与其他已有字符串比较,比如城市,则可能需要调整大小写,这里就需要用到大小写转换工具了,具体方法为toLowerCase()和toUpperCase()方法,举例如下:
1 var city = "ShanGHai"; 2 city = city.toLowerCase(); // city is "shanghai" now.
五、字符串相等。
如果要用用户的值与自己数据库中的值作比较,则要用到字符串比较方法,主要两种方法,一种是“==”,另一种是“===”。
对于第一种方法,是完全向后兼容的,标准的"==",如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转换。例如下面的语句,
1 var strA = "i love you!"; 2 var strB = new String("i love you!");
这两个变量含有相同的字符序列,但数据类型却不同,前者为string,后者为object,在使用"=="操作符时,JavaScript会尝试各种求值,以检测两者是否会在某种情况下相等。所以上面的表达式结果为true: strA == strB。
对于第二种方法,是严格的,它在求值时不会这么宽容,不会进行类型转换。所以上述表达式strA === strB的值为false,虽然两个变量持有的值相同。
六、字符串查找。
这里的字符串查找是说判断一个字符串是否包含另一个字符串。用到的方法为indexOf,跟java不一样,不是contains,我个人在这个问题上出过错,所以还是要谨记。
用法为strObj.indexOf(subString[, startIndex]),这里strObj是要判断的字符串,startIndex是可选的,表示查找的开始位置(基于0的索引),如果startIndex省略,则从strObj开始处查找,如果startIndex小于0,则从0开始,如果startIndex大于最大索引,则从最大索引处开始。indexOf()返回strObj中subString的开始位置,如果没有找到,则返回-1。可以如下使用:
1 if(largeString.indexOf(shortString) != -1) 2 { 3 // 如果包含,进行相应处理; 4 }
也许一个字符串会包含另一字符串不止一次,这时第二个参数startIndex也许会派上用场,下面这个函数演示如何求得一个字符串包含另外一个字符串的次数:
1 function countInstances(mainStr, subStr) 2 { 3 var count = 0; 4 var offset = 0; 5 do 6 { 7 offset = mainStr.indexOf(subStr, offset); 8 if(offset != -1) 9 { 10 count++; 11 offset += subStr.length; 12 } 13 }while(offset != -1) 14 return count; 15 }
String对象有一个与indexOf()对应的方法,lastIndexOf():
1 strObj.lastIndexOf(substring[, startindex])
strObj为要进行判断的字符串,subString为要在strObj查找的子字符串,startIndex是可选的,表示查找的开始位置(基于0的索引),如果startIndex省略,则从strObj末尾处查找,如果startIndex小于0,则从0开始,如果startIndex大于最大索引,则从最大索引处开始。该方法自右向左查找,返回subString在strObj中最后出现的位置,如果没有找到,返回-1。
以上就是我最近学习到的js中关于string的一些基本用法的总结,还有很多不足之处,并且一些常用但是我没用过的我也没写上,以后用到可以继续添加,也希望大家看到问题批评指正。