虽然 JavaScript 有很多用处,但是处理字符串是其中最流行的一个。下面让我们深入地分析一下使用 JavaScript 操作字符串。在 JavaScript 中, String 是对象。 String 对象并不是以字符数组的方式存储的,所以我们必须使用内建函数来操纵它们的值。这些内建函数提供了不同的方法来访问字符串变量的内容。下面我们详细看一下这些函数。

包罗万象

操作字符串的值是一般的开发人员必须面临的家常便饭。操作字符串的具体方式有很多,比如说从一个字符串是提取出一部分内容来,或者确定一个字符串是否包含一个特定的字符。下面的 JavaScript 函数为开发人员提供了他们所需要的所有功能:

•  concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串。

•  indexOf() – 返回字符串中一个子串第一处出现的索引。如果没有匹配项,返回 -1 。

•  charAT() – 返回指定位置的字符。

•  lastIndexOf() – 返回字符串中一个子串最后一处出现的索引,如果没有匹配项,返回 -1 。

•  match() – 检查一个字符串是否匹配一个正则表达式。

•  substring() – 返回字符串的一个子串。传入参数是起始位置和结束位置。

•  replace() – 用来查找匹配一个正则表达式的字符串,然后使用新字符串代替匹配的字符串。

•  search() – 执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。

•  slice() – 提取字符串的一部分,并返回一个新字符串。

•  split() – 通过将字符串划分成子串,将一个字符串做成一个字符串数组。

•  length() – 返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。

•  toLowerCase() – 将整个字符串转成小写字母。

•  toUpperCase() – 将整个字符串转成大写字母。

注意: concat 、 match 、 replace 和 search 函数是在 JavaScript 1.2 中加入的。所有其它函数在 JavaScript 1.0 就已经提供了。

下面让我们看一下如何在 JavaScript 使用这些函数。下面的代码是用到了前面提到的所有函数:

 1 function manipulateString(passedString1, passedString2) {
 2
 3 var concatString;
 4
 5 // The string passed to concat is added to the end of the first string
 6
 7 concatString = passedString1.concat(passedString2);
 8
 9 alert(concatString);
10
11 // The following if statement will be true since first word is Tony
12
13 if (concatString.charAt(3) == "y") {
14
15 alert("Character found!");
16
17 }
18
19 // The last position of the letter n is 10
20
21 alert("The last index of n is: " + concatString.lastIndexOf("n"));
22
23 // A regular expression is used to locate and replace the substring
24
25 var newString = concatString.replace(/Tony/gi,"General");
26
27 // The following yields Please salute General Patton
28
29 alert("Please salute " + newString);
30
31 // The match function returns an array containing all matches found
32
33 matchArray = concatString.match(/Tony/gi);
34
35 for (var i=0; i<matchArray.length;i++) {
36
37 alert("Match found: " + matchArray[i]);
38
39 }
40
41 // Determine if the regular expression is found, a –1 indicates no
42
43 if (newString.search(/Tony/) == -1) {
44
45 alert("String not found");
46
47 } else {
48
49 alert("String found.");
50
51 }
52
53 // Extract a portion of the string and store it in a new variable
54
55 var sliceString = newString.slice(newString.indexOf("l")+2,newString.length);
56
57 alert(sliceString);
58
59 // The split function creates a new array containing each value separated by a space
60
61 stringArray = concatString.split(" ");
62
63 for (var i=0; i<stringArray.length;i++) {
64
65 alert(stringArray[i];
66
67 }
68
69 alert(newString.toUpperCase());
70
71 alert(newString.toLowerCase());
72
73 } 

下面是执行上面的代码得到的结果:

Tony Patton
Character Found!
The last index of n is: 10
Match found: Tony
Please salute General Patton
String not found
Patton
Tony
Patton
GENERAL PATTON
general patton

示例代码把所有这些提到的函数都用到了。

特殊字符

除了这些函数之外,还有很多的特殊字符可以用来表示关键的效果。这些特殊字符包括:

•  \t – 跳格键

•  \b – 退格 / 删除

•  \r – 回车

•  \n – 换行

•  \f – 换页

特殊字符最常见的用途就是格式化输出。例如,你可能需要在输出中插入一个换行来正确地显示一个值。而且,在换行时也需要回车。在一些平台上,“ \n ”已经足够产生换行效果了,而在一些机器上要正确地显示一个换行则需要“ \r\n ”。下面的例子显示了在一个多行窗口上显示的特殊字符:

var output = null;
output = "Special Characters";
output += "\n";
output += "===============";
output += "\n";
output += "\\t - tab";
output += "\n";
output += "\\b - backspace/delete";
output += "\n";
output += "\\r - carriage return";
output += "\n";
output += "\\n - newline";
output += "\n";
output += "\\f - form feed";
output += "\n";
alert(output);

前面的例子使用加号来连接字符串,而没有使用 concat 函数。原因很简单,对于 concat 函数来说,每一个操作都需要一个新的变量;反之,我们这里用的这种方法则简单地扩展了原有的值,而不需要新的变量。而且,示例中使用换码符来正确地显示特殊字符。系统将一个反斜线当作一个信号,认为它后面会跟一个特殊字符,但是连着两个反斜线则抵消这种操作。输出中的每个字符都通过 newline 特殊字符被显示在新的一行。

添加到工具箱中

特殊字符和函数可以与其它 JavaScript 技巧结合起来解决很多问题。其中一种情况是用来进行 JavaScript 客户端表单验证,这篇文章中提出的方法可以简单地用来实现表单验证。

下面的代码将在一个表单被提交时调用。要提交的表单包含三个域:名称、地址和邮政编码。为了实现起来比较简单,我们只验证每个域都不能为空,并且邮政编码必须是数字。下面的 JavaScript 代码完成这一功能:

 1 function validation() {
 2
 3 var doc = document.forms[0];
 4
 5 var msg = "";
 6
 7 if (doc.Name.value == "") {
 8
 9 msg += "- Name is missing\n";
10
11 }
12
13 if (doc.Address.value == "") {
14
15 msg += "- Address is missing\n";
16
17 }
18
19 if (doc.ZipCode.value == "") {
20
21 msg += "- Zip code is missing\n";
22
23 }
24
25 var zip = new String(doc.ZipCode.value);
26
27 if (zip.search(/^[0-9][0-9][0-9][0-9][0-9]$/)==-1) {
28
29 msg += "- Enter valid Zip code";
30
31 }
32
33 if (msg == "") {
34
35 doc.submit;
36
37 } else {
38
39 msg = "Please correct the following validation errors and re-submit:\n\n" + msg;
40
41 alert(msg);
42
43 }
44
45 }
46
47 

在用户提交表单时,这个函数就会被调用。对函数的调用是在一个 HTML 按钮的 onSubmit 事件中实现的。

<input type="button" type="submit" value="submit" onClick="validation()">

验证函数检查每个域是否为空。如果发现了一个空值,那么就会在验证消息变量 msg 后面添加一个出错消息。此外,还使用了一个正则表达式来验证邮政编码域的格式。在这里,我们只接受五位数的美国地区邮政编码。如果发现有任何错误(即 msg 变量不为空),那么程序就会显示一个错误消息;否则的话,程序就会提交表单。

一门强大的语言

JavaScript 已经发展成熟为一种功能完备的语言,能够用来构建强大的应用程序。它是对具有非连接性天性的 Web 界面的一个完美的补充,能够在不与 Web 服务器交互的情况下完成很多客户端操作。

转载于:https://www.cnblogs.com/hzuIT/articles/745804.html

用 JavaScript 操作字符串相关推荐

  1. js(JavaScript)操作字符串的方法

    今天被字符串操作上了一课,一气之下把字符串的所有方法整了一遍 <script>let str1 = "abc8ABCabc"let str2 = "xyz&q ...

  2. Javascript操作DOM常用API总结

    文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...

  3. 整理javascript操作文件说明.

    Javascript是网页制作中离不开的脚本语言,依靠它,一个网页的内容才生动活泼.富有朝气.但也许你还没有发现并应用它的一些更高级的功能吧?比如,对文件和文件夹进行读.写和删除,就象在VB.VC等高 ...

  4. 【repost】Javascript操作DOM常用API总结

    Javascript操作DOM常用API总结 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认 ...

  5. 字符串处理_5个JavaScript的字符串处理库,不再996

    处理大小写转换,删除字母符号,Unicode处理,URL处理等 使用字符串可能是一项繁琐的任务,因为有许多不同的用例.例如,将字符串转换为驼峰大小写这样的简单任务可能需要几行代码才能达到最终目标. f ...

  6. 如何使用JavaScript从字符串中删除空格?

    本文翻译自:How to remove spaces from a string using JavaScript? How to remove spaces in a string? 如何删除字符串 ...

  7. javaScript的字符串

    JavaScript的字符串就是用"或"括起来的字符表示. js操作字符串使用的对象: String 注意:对字符串的操作的api返回的字符串都是一个新对象,如果需要使用的话需要新 ...

  8. JavaScript操作DOM对象 Day05

    JavaScript操作DOM对象 0 核心 浏览器网页就是一个Dom树形结构! 获取Dom节点:得到Dom节点 更新:更新Dom节点 添加:添加一个新的节点 删除:删除一个Dom节点 要操作一个Do ...

  9. javascript操作数组的方法大全

    javascript操作数组的方法大全 一.ES5数组的方法 1.Array.isArray() 用来判断是否为数组 var arr = [1, 2, 3, 4, 5]; var obj = {}; ...

最新文章

  1. matlab textsac函数,哈工大-Matlab--2013年春季学期《MATLAB语言及应用》试题
  2. 使用next_permutation()的坑,你中招了么?
  3. Android中实现自定义View组件并使其能跟随鼠标移动
  4. 简单的python画图代码_python opencv如何实现简易画图板 python opencv实现简易画图板代码...
  5. 大数据学习笔记29:Hadoop压缩机制演示
  6. unity3d Aniso Level 摄像机近地面清楚,远地面模糊
  7. C# asp.net常见编译|运行错误
  8. java时间转化类,一小时前,刚刚一个月前
  9. asp得到地址栏里?以后的字串
  10. 勤哲excel服务器点击修改,用勤哲Excel服务器实现工作任务管理系统
  11. java 移位运算符
  12. 经典配色方案之 红、橙、黄、绿、青、紫、无彩色系
  13. 解决POI导出Excel单元格内容换行问题
  14. Curious Array
  15. 终端模拟器怎么用android命令大全,终端模拟器命令大全apk下载-终端模拟器刷入recovery手机版下载V1.0.70安卓最新版-西西软件下载...
  16. 27岁,大专学历,女程序员内心的感受和行业焦虑
  17. ofo押金是否可以起诉_是否可以因应用程序中的错误而被起诉?
  18. mysql数据库语言_mysql数据库sql语句基础知识
  19. 计算机设备调试及维护,计算机安装、调试及维护工职业标准-简.doc
  20. PHPMyWind支持Word粘贴

热门文章

  1. C++ STL容器之 list 初步
  2. Linux网络编程——I/O复用函数之epoll
  3. select、poll、epoll 比较
  4. 力扣(LeetCode)292. Nim游戏 巴什博奕
  5. Day 4:集合——迭代器与List接口
  6. 判断IE版本与各浏览器的语句
  7. jquerymobile应用中session、cookie
  8. 将博客文章转变为电子书
  9. CentOS5.6环境安装oracle 10g(完整版)
  10. AutoScaling 与函数计算结合,赋予更丰富的弹性能力