javascript中很经常的会用到string类型的变量,对此,总结了几种常用操作或者方法:创建、拼接、子串、大小写转换、判断字符串相等、字符串查找等几种。下面将一一简单描述。

一、js中string的创建。

创建string变量可以说有两种:

一种是最基本的直接声明然后初始化的情况,用引号将一组字符包含起来,这里的引号可以是一对单引号也可以是一对双引号,但是不能是一个单引号和一个双引号组合的形式,即下面的是不正确的。

 var myString = "Fluffy is a pretty cat.';

另一种是用新建对象的形式新建string对象。举例:

 var str1 = "Hello world!";
var str2 = new String("I love you!");

这两种方式都可以新建str变量,但是这两种方式还是不同的,第一种是建立了一个字符串类型的值,而第二种是建立了字符串类型的对象。用typeof运算符可看出,第一种是string,而第二种是Object。

如果想知道字符串长度可以通过length的方式获得,即str1.length。如果想得到字符串指定位置的字符可通过charAt的方式获取。

二、字符串拼接。

字符串拼接是指将两个字符串放到一块组成一个大的新的字符串,拼接也有两种简单方式:

一种是简单地用“+”进行拼接,

 var str = "hello," + " world!";

如果有多个进行拼接,可以使用“+=”进行拼接。

 var result = "";
result += "My name is Anders"
result += " and my age is 25";

String对象还提供了方法concat(),它完成与"+"相同的功能:

 string.concat(value1, value2, ...)

不过concat()方法显然不如"+"来得直观简洁。

三、访问子串

这里的访问子串的意思就是获取字符串的一部分文本,同样有两种方法,一种是substring(),一种是slice()

substring的用法是string.substring(from,to),根据参数就可以看出其具体用法,返回的是从from开始(包括from位置)到end结束(不包括end)中的字符串,from指明了子字符串在原字符串中起始位置,这里要注意是基于0索引的,to是可选的,它指明了子字符串的结束位置,同样是基于0索引的,如果被忽略,则结束位置默认为原字符串的结束。

一般情况下他应该比from的值大,否则,系统将自动调整两者的大小,将小的值作为起始位置,大的值作为结束位置。

举例如下:

 var fullString = "Every dog has his day.";
var section = fullString.substring(0, 4); // section is "Ever".
section = fullString.substring(4, 0); // section is also "Ever".
section = fullString.substring(1, 1); // section is an empty string.
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()方法,举例如下:

 var city = "ShanGHai";
city = city.toLowerCase(); // city is "shanghai" now.

五、字符串相等。

如果要用用户的值与自己数据库中的值作比较,则要用到字符串比较方法,主要两种方法,一种是“==”,另一种是“===”。

对于第一种方法,是完全向后兼容的,标准的"==",如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转换。例如下面的语句,

 var strA = "i love you!";
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。可以如下使用:

 if(largeString.indexOf(shortString) != -1)
{
// 如果包含,进行相应处理;
}

也许一个字符串会包含另一字符串不止一次,这时第二个参数startIndex也许会派上用场,下面这个函数演示如何求得一个字符串包含另外一个字符串的次数:

 function countInstances(mainStr, subStr)
{
var count = 0;
var offset = 0;
do
{
offset = mainStr.indexOf(subStr, offset);
if(offset != -1)
{
count++;
offset += subStr.length;
}
}while(offset != -1)
return count;
}

String对象有一个与indexOf()对应的方法,lastIndexOf():

 strObj.lastIndexOf(substring[, startindex])

strObj为要进行判断的字符串,subString为要在strObj查找的子字符串,startIndex是可选的,表示查找的开始位置(基于0的索引),如果startIndex省略,则从strObj末尾处查找,如果startIndex小于0,则从0开始,如果startIndex大于最大索引,则从最大索引处开始。该方法自右向左查找,返回subString在strObj中最后出现的位置,如果没有找到,返回-1。

以上就是我最近学习到的js中关于string的一些基本用法的总结,还有很多不足之处,并且一些常用但是我没用过的我也没写上,以后用到可以继续添加,也希望大家看到问题批评指正。

javascript中string的用法总结的更多相关文章

  1. JavaScript中String对象的match()、replace() 配合正则表达式使用

    正则表达式由来已久,查找替换功能非常强大,但模板难记复杂. JavaScript中String对象的match().replace()这2个方法都要使用正则表达式的模板.当模板内容与字符串不相匹配时, ...

  2. C#中string.format用法详解

    C#中string.format用法详解 本文实例总结了C#中string.format用法.分享给大家供大家参考.具体分析如下: String.Format 方法的几种定义: String.Form ...

  3. JavaScript中return的用法详解

    JavaScript中return的用法详解 最近,跟身边学前端的朋友了解,有很多人对函数中的this的用法和指向问题比较模糊,这里写一篇博客跟大家一起探讨一下this的用法和指向性问题. 1定义 t ...

  4. C#中string.Format 用法详解

    这篇文章主要介绍了C#中string.format用法,以实例形式较为详细的讲述了string.format格式化的各种用法,非常具有实用价值,需要的朋友可以参考下 本文实例总结了C#中string. ...

  5. JavaScript中this的用法 及 如何改变this的指向

    要懂得JavaScript中this的用法,首先需要知道,JavaScript中的作用域相关知识. var fun = function(){ var flag = 1; console.log(fl ...

  6. javascript中 try catch用法

    javascript中 try catch用法 投稿:hebedich 字体:[增加 减小] 类型:转载 时间:2015-08-16我要评论 JS try catch语句一般在什么情况下使用?是必须使 ...

  7. 从函数调用的角度,探讨JavaScript中this的用法

    js函数调用方式大概可分为:函数调用,构造器调用,call或apply,方法调用四种方式.下面结合一些基础概念和实测代码,从函数调用的角度,探讨JavaScript中this的用法. 1. new对函 ...

  8. JavaScript中this的用法详解

    JavaScript中this的用法详解 最近,跟身边学前端的朋友了解,有很多人对函数中的this的用法和指向问题比较模糊,这里写一篇博客跟大家一起探讨一下this的用法和指向性问题. 1定义 thi ...

  9. java成神之——java中string的用法

    java中String的用法 String基本用法 String分割 String拼接 String截取 String换行符和format格式化 String反转字符串和去除空白字符 String获取 ...

随机推荐

  1. sgu 195 New Year Bonus Grant【简单贪心】

    链接: http://acm.sgu.ru/problem.php?contest=0&problem=195 http://acm.hust.edu.cn/vjudge/contest/vi ...

  2. spring boot数据库操作汇总

    1 关于orm orm即object relational mapping,对象关系映射,即将数据库中的表映射成对象. 常用的orm有以下: mybatis spring jdbc template ...

  3. swift 一句代码补全tableView分割线

    1.swift实现分割线补全 swift一个大进步,只要设置tableView.separatorInset = UIEdgeInsets.zero即可补全分割线, 2.OC实现分割线补全 而在OC中 ...

  4. 【python】-- Socket

    socket socket本质上就是在2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递. 我们知道网络 通信 都 是基于 ip+port 方能定位到目标的具体机器上的具体 ...

  5. 修改maven的war包生成路径

    因为要配合jenkins,所以控制了war包的生成目录: <plugins> <!--打war包到指定的目录下 --> <plugin> <groupId&g ...

  6. 区分Web前端和后端(转载)

    转载自:http://blog.csdn.net/rosetta/article/details/53871766 前言   做C开发将近六年,基本上没有接触过web相关的东西,原来听别人说web相关 ...

  7. Java多线程系列 JUC锁06 Condition条件

    Condition介绍 Condition中提供了一组类似于Object中的监视器方法.与Lock配合可以完成等待通知模式. Lock lock = new ReentrantLock(); Cond ...

  8. js常用方法(。。。。不完整)

    lastIndexOf();substring();split();slice();splice(); var s="http://www.baidu.com"; var unit ...

  9. python编写脚本应用实例

    这里主要记录工作中应用python编写脚本的实例.由于shell脚本操作数据库(增.删.改.查)并不是十分直观方便,故这里采用python监控mysql状态,然后将状态保存到数据库中,供前台页面进行调 ...

  10. Python 3 mysql 数据类型

    Python 3 mysql 数据类型 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 详细参考: http://www.runoob.com/m ...