用 JavaScript 操作字符串

虽然 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407942.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

The Ranges Library --- C++20

The Ranges Library — C20 ranges可以让我们更加舒服的写代码了, 不用再敲那么多的代码 之前我们需要这样标准库的算法对容器的操作 #include <iostream> #include <ranges> #include <vector> #include <algorithm>int main() {std::vector vec{ …

什么是反射(.NET)[转]

From: http://www.cnblogs.com/zxsoft/archive/2007/09/17/895236.html 反射&#xff08;Reflection&#xff09;是.NET中的重要机制&#xff0c;通过放射&#xff0c;可以在运行时获得.NET中每一个类型&#xff08;包括类、结构、委托、接口和枚举等&#xff09;的成员&#x…

Yii权限管理工具Srbac使用小结

一、关于Srbac Srbac是基于Yii 框架的 RBAC&#xff08;基于角色的访问控制&#xff09; 插件模块&#xff0c;用于帮助Yii开发人员更方便地进行权限控制&#xff0c;在实际应用过程中也比较方便。 二、安装配置Srbac 在Yii的官方网站的Extensions中已经收录了Srbac插件&#x…

概念concept和requires ---C++ 20

概念concept和requires —C 20 concept concept简化了模板编程的难度 我们可以使用**concept定义模板形参的约束条件T** 模板实力替换T后必须满足std::is_integral_v<C>;为true 例子: requires关键字可以直接约束模板形参T 如下: template <class C> concept …

辞职中

不知道为什么就不想再做下去了&#xff0c;说不上来工作有什么好&#xff0c;当然也说不上来什么不好。SP这个行业&#xff0c;可能不太适合我。准备走了&#xff0c;考研还是继续找工作&#xff1f;我不知道该怎么走&#xff01;看着前面都是路却找不到一条适合自己的。转载于…

向DataGridView中添加新的一行数据,可以添加到最后一行或作为第一行

我的开发环境&#xff1a;Microsoft Visual Studio .net 2005 这个程序是Windows Forms Application 新建一个Windows Forms Application项目&#xff0c;打开Form1&#xff0c;在窗体上放一个DataGridView控件和Button,在DataGridView的Columns中添加两列&#xff0c;Name分别…

Linq学习

IEnumerable<DataRow> cbCurrent from dr in cbRows.AsEnumerable() where dr.Field<string>("ObjectNO").ToString() row["运输单号"].…

非类型模板参数(参考《C++ Templates 英文版第二版》)

非类型模板参数(参考《C Templates 英文版第二版》) Chapter 3 3.1 非类型类模板参数 与前几章的简单例子不同,你也可以通过std::array实例化一个固定大小的栈,这样做的优点在于内存管理, #include <array> #include <cassert>template<typename T, std::si…

I AM NOTHING vs I AM SOMETHING

女友推荐链接&#xff1a;BBS上一个女生的创业感言 自创业的一路艰辛 http://bbs.trendsmag.com/showthread.php?t163960

DataGridView添加一行数据、全选、取消全选、清空数据、删除选中行

.net 2005下的Windows Form Application,一个DataGridView控件和4个Button&#xff0c;界面设置如下&#xff1a; 代码如下&#xff0c;有注解&#xff0c;相信大家都看得明白&#xff1a; using System;using System.Collections.Generic;using System.ComponentModel;using S…

类型萃取类型检查 Type-Traits LibraryType Checks --- C++20

类型萃取:类型检查 Type-Traits Library:Type Checks — C20 Type-Traits library 在C11的时候就已经发布,但依然随着C版本在不断更新 类型检查 Type Checks 每种类型就是十四种主要类型之一 主要类型 template <class T> struct is_void; template <class T>…

转:如何在 LoadRunner 脚本中做关联 (Correlation)

如何在 LoadRunner 脚本中做关联 (Correlation) 当录制脚本时&#xff0c;VuGen会拦截client端&#xff08;浏览器&#xff09;与server端&#xff08;网站服务器&#xff09;之间的对话&#xff0c;并且通通记录下来&#xff0c;产生脚本。在VuGen的Recording Log中&#xff0…

开博碎语

结束了5月26号的软考&#xff0c;就萌生了建一个技术博客的想法-----技术或许太空泛&#xff0c;其实就是把工作中&#xff0c;学习上技术方面的一些资料&#xff0c;一些体会汇聚一起&#xff0c;呈现出来&#xff0c;博客当然是个不错的选择。baidu一下&#xff0c;技术博客为…

DateTime时间的比较问题

关于DateTime时间的比较问题&#xff0c;我现在不清楚使用> < 和DateTime.Compare(t1, t2)、t1.CompareTo(t2)的区别。 下面是一个简单的测试程序&#xff0c;至少到现在为止&#xff0c;我还没有发现这两种比较的区别之处&#xff0c;大家有任何自己的想法&#xff0c;…

模板元编程 Template Metaprogramming--- C++ 20

模板元编程(一) Template Metaprogramming— C 20 在编译期进行类型操作 举个例子: std::move在概念上应该这样实现(实际并不是这么做的): static_cast<std::remove_reference<decltype(arg)>::type&&>(arg);意义上,std::move首先获取它的参数arg,推断…

6月,启蒙篇

6月&#xff0c;哈哈 在过去的4月与5月里我一直放荡着自己&#xff0c;我发现一个人没有目标与理想后是这样的无耐 &#xff0c;也是这样的无所做为。在那两个月里我放弃了所有的程序&#xff0c;我只是在计算机前玩游戏 。我原本以为这样会过得开心点&#xff0c;会让自己放松…