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. Office Web Apps Server 2013与PDF(二)

    在上一篇文章(Office Web Apps Server 2013与PDF(一))中,曾经介绍了Office Web Apps Server 2013在更新后,可以直接对PDF文档进行在线的查看.不 ...

  2. 九度OJ 1201:二叉排序树 (二叉树)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4894 解决:2062 题目描述: 输入一系列整数,建立二叉排序数,并进行前序,中序,后序遍历. 输入: 输入第一行包括一个整数n(1< ...

  3. hibernate 多对多 懒加载问题

    报错:org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: net. ...

  4. linux后台开发必备技能

    一.linux和os: 1.命令:netstat tcpdump ipcs ipcrm  这四个命令的熟练掌握程度基本上能体现实际开发和调试程序的经验 2.cpu 内存 硬盘 等等与系统性能调试相关的 ...

  5. Spring MVC 通过反射将数据导出到excel

    直接上代码 // 导出excel方法 @RequestMapping("exportExcel") public void exportExcel(HttpServletReque ...

  6. Facial landmark detection - 人脸关键点检测

    Facial landmark detection  (Facial keypoints detection) OpenSourceLibrary: DLib Project Home:  http: ...

  7. ubuntu配置jdk环境

    简单记录如下: 1. 下载JDK并解压后,复制到想要放置的目录,本文以“/usr/lib/jdk”为例: 2. 编辑配置文件,可以是“/etc/profile”或者“~/.bashrc”. 输入命令“ ...

  8. P4965 薇尔莉特的打字机

    题目 P4965 薇尔莉特的打字机 快到十二点了正在颓废突然发现了一道好题 虽然毒瘤,但确实是容斥原理的好题啊,做法也特别巧妙(标程 思路 题目大意(怕自己突然忘) n个初始字符,m个操作(加入或删除 ...

  9. curl常用指令

    curl 发送GET请求获取标准输出 curl -I 显示http请求头 curl -i 显示请求头及输出内容 curl xxx > xxx 将输出重定向到本地文件(本地文件无需已存在,一般不写 ...

  10. dsp2812 pwm配置

    肚子疼了好几天,今天稍微好点,简单写点东西. 好几个月前做的项目,有些地方已经记不清楚了,但是突然客户又来问关于代码配置的情况,重新查看了代码,把相关的知识也整理一下. dsp2812中有好几个时钟相 ...