javascript中string的用法总结

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的一些基本用法的总结,还有很多不足之处,并且一些常用但是我没用过的我也没写上,以后用到可以继续添加,也希望大家看到问题批评指正。

33人参与, 0条评论 登录后显示评论回复

你需要登录后才能评论 登录/ 注册