注册通行证 用户名 密码
  • 文章投稿
  • 博客
  • 论坛
  • 设为首页
  • 加入收藏
jztop.com网络技术
  • 首页
  • | iT新闻
  • | 操作系统
  • | 组网建网
  • | 网络安全
  • | 程序开发
  • | 办公一族
  • | 工具软件
  • | 网页制作
  • | 多媒体制作
  • | 网吧技术
  • | 服务器
  • | 专题教程
Vista | 软件评测 | 系统备份 | 优化 | 进程 | 聊天 | 病毒 | Linux | 黑客 | 防火墙 | 数据库 | Web开发 | Java | Word | 游戏 | 32位开发 | 移动开发
当前位置:首页 > 网页制作 > JavaScript技术 内容正文:用 JavaScript 来操作字符串的函数

用 JavaScript 来操作字符串的函数

发布时间:2006-08-01 09:43:00 来源:天极网 网友评论 0 条

虽然 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 服务器交互的情况下完成很多客户端操作。

  新版网页陶吧上线
  

相关文章
  • JavaScript代码可导致浏览器攻击
  • JavaScript实现网页图片等比例缩放
  • 判断浏览器是否支持JavaScript和Cookies
  • 特效代码:一个非常实用的Javascript类库
  • 应用实例:用Javascript实现定时任务
【评论】【收藏本文】【打印】【关闭】
上一篇文章:JavaScript代码可导致浏览器攻击
下一篇文章:页面中文乱码之完全Script解决方案
讨论区
查看
已有 0 位对此新闻感兴趣的网友发表了看法
匿名发表
注册通行证 登陆
图文阅读推荐
推荐阅讯
  • JS实现Flash外链专题大图片的轮显效果
  • 脚本实例:用 JavaScript 来操作字符串
  • JavaScript高级程序设计:2.2 变量
  • 一个表单日期输入的JS脚本 非常实用
  • Javscript实现表单复选框的全选功能
  • 如何用javascript控制上传文件的大小
  • 飘浮广告的显示脚本类(VBS,JS双版)
  • 网页特效:随机显示广告的JS源代码
  • 特效:类似于marquee文字向左运动
  • JavaScript高级程序设计:2.1 语法
阅读排行
  • 1.网页特效:一段实用的图片滚动显示代码
  • 2.网页特效实例:用js获取单选按钮的数据
  • 3.Javascript特效:随机显示图片的源代码
  • 4.Javascript技术技巧大全
  • 5.IE和FireFox下javascript读写XML实现广告轮
  • 6.用 JavaScript 来操作字符串的函数
  • 7.添加到收藏夹的Javascript脚本-适合IE和Fir
  • 8.怎样判断浏览器是否支持javascript?
  • 9.JavaScript实现网页图片等比例缩放
  • 10.网页特效:随机显示广告的JS源代码
专题教程
  • 大话G游 专题:手机病毒揭密
  • ARP攻击防范与解决方案 路由故障处理手册
  • Picasa中文版_Picasa教程 专题:清除流氓软件
  • Firefox专题 seo搜索引擎优化专区
  • 重装Windows必知的事情 装机之必备软件大行动
病毒专杀栏
  • 杀毒软件反被病毒杀 连"救命"都不能喊
  • 金山ARP防火墙
  • 还原卡神话破灭“机器狗”病毒来势汹汹
  • cctv经济半小时:你的手机现在安全吗?
  • 新挂马方式开始流行 ARP挂马称雄局域网
  • 木马和病毒清除的通用解法
  • IP地址不再冲突 查找ARP攻击者元凶
  • 教你几招识别和防御Web网页木马
  • 分析:封杀BT只是暂时的止痛药
  • QQ爆危险漏洞,“QQ游戏邀请大盗”邀请你玩病
关于我们 | 诚聘英才 | 联系我们 | 版权声明 | 网站大事 | 网站地图 | 意见建议
CopyRight 2005-2007 Jztop.Com 版权所有 未经许可 请勿转载