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

  • 相关阅读:
    Linux命令未找到(command not found),误删Linux path原始路径
    Linux安装JDK1.8
    Python批量修改文件夹内所有json文件中部分内容
    [转]jQuery插件开发精品教程,让你的jQuery提升一个台阶
    使用apache的ab对页面进行压力测试
    http_load压力测试
    php json_encode数据格式化2种格式[]和{}
    PHP接收JSON格式的数据
    新浪短链接API接口示例
    一个提示样式
  • 原文地址:https://www.cnblogs.com/Pillar/p/4204178.html
Copyright © 2011-2022 走看看