JavaScript学习(十四)---String对象中的模式匹配方法

简介: 目录1.match()方法语法:stringobj.match(rgExp)例子:2.search()方法语法:stringobj.search(rgExp)例子:3.replace()方法语法:replace(rgExp.replaceText)例子:4.split()方法语法:split([separator[,limit]])1.match()方法match()方法使用正则表达式模式对字符串进行查找,并将包含查找的结果作为数组返回。

目录

1.match()方法

语法:stringobj.match(rgExp)

例子:

2.search()方法

语法:stringobj.search(rgExp)

例子:

3.replace()方法

语法:replace(rgExp.replaceText)

例子:

4.split()方法

语法:split([separator[,limit]])


1.match()方法

match()方法使用正则表达式模式对字符串进行查找,并将包含查找的结果作为数组返回。

语法:stringobj.match(rgExp)

stringobj:必选项。对其进行查找的String对象或字符串文字

rgExp:必选项。为正则表达式模式和可用标志的正则表达式对象。也可以是包含正则表达式模式和可用标志的变量名或字符串文字。

如果match方法没有找到匹配,则返回null。如果找到匹配则返回一个数组并且更新全局RegExp对象的属性以反映结果。

match方法返回的数组有3个属性:input,index,lastindex。

如果没有全局标志(g),数组的0元素包含整个匹配,而第1-n元素包含了匹配中曾出现过的任一子匹配。这相当于没有设置全局标志,元素0-n中包含所有匹配。

例子:

        <script language="JavaScript">
			function MatchDemo(){
				var r,re;         //声明变量
				var s="I'm a good man"; 
				re=/man/i;       //创建正则表达式
				r=s.match(re);    //尝试匹配搜索字符串
				return(r);        //返回第一次出现"body"的地方
			}
			document.write(MatchDemo());
		</script>	
        <script language="JavaScript">
			function MatchDemo(){
				var r,re;         //声明变量
				var s="I'm a man a good man"; 
				re=/man/ig;       //创建正则表达式
				r=s.match(re);    //尝试匹配搜索字符串
				return(r);        //返回第一次出现"body"的地方
			}
			document.write(MatchDemo());
		</script>	

 

2.search()方法

search()方法返回与正则表达式查找内容匹配的第一个子字符串的位置。

语法:stringobj.search(rgExp)

stringobj:必选项。对其进行查找的String对象或字符串文字

rgExp:必选项。为正则表达式模式和可用标志的正则表达式对象。也可以是包含正则表达式模式和可用标志的变量名或字符串文字。

例子:

            <script language="JavaScript">
			function MatchDemo(){
				var r,re;         //声明变量
				var s="I'm a man a good man"; 
				re=/man/ig;       //创建正则表达式
				r=s.search(re);    //尝试匹配搜索字符串
				return(r);        //返回第一次出现"body"的地方
			}
			document.write(MatchDemo());
		</script>	

3.replace()方法

replace()方法使用表达式模式对字符串进行搜索,并对搜索后到的内容用指定字符串替代,返回一个字符串对象,包含替换后的内容。

语法:replace(rgExp.replaceText)

rgExp参数为搜索时要使用的表达式对象。如果是字符串,不按正则表达式的方式进行模糊搜索,而是进行精确搜索。

replaceText参数为用于替换搜索到的内容的字符串,其中可以使用一些特殊的字符组合来表示匹配变量。其中,$&是整个表达式模式在被搜索字符串中所匹配的字符串,$是表达式模式在被搜索字符串中所匹配的字符串左边的所有内容,$‘是表达式在被搜索字符串中所匹配的字符串右边的所有内容,$$则是普通意义的“$”字符。

例子:

        <script language="JavaScript">
			var strSrc="a13f58af4f41af";
			var re=/(\d)(\d)/gi;
			var strDest=strSrc.replace(re,"$2$1");
			document.write("字符串"+strSrc+"被转化为:"+strDest);
		</script>	

4.split()方法

split()方法返回按照某种分割标识符将一个字符串拆分成若干个子字符串时所产生的子字符串数组。

语法:split([separator[,limit]])

separator是分割标识符参数,可以是多个字符或一个正则表达式,并不作为返回到数组元素的一部分。参数limit限制返回元素的个数。

            <font size="+1">
		<font face="宋体">
		<script language="JavaScript">
			var splitArray=new Array();
			var string="JavaScript、ASP、JSP、Java";
			var regex=/、/;
			splitArray=string.split(regex);
			for(i=0;i<splitArray.length;i++){
				document.write(splitArray[i]+" ");
			}
		</script>	

目录
相关文章
|
7月前
|
监控 负载均衡 JavaScript
有哪些有效的方法可以优化Node.js应用的性能?
有哪些有效的方法可以优化Node.js应用的性能?
357 69
|
6月前
|
前端开发 JavaScript
个人征信电子版无痕修改, 个人信用报告pdf修改,js+html+css即可实现【仅供学习用途】
本代码展示了一个信用知识学习系统的前端实现,包含评分计算、因素分析和建议生成功能。所有数据均为模拟生成
|
6月前
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法详解
本指南详细介绍在Linux系统中安装和管理Node.js的步骤。首先检查现有环境,包括查看当前版本和清除旧版本;接着通过NodeSource仓库安装最新版Node.js并验证安装结果。推荐使用nvm(Node Version Manager)进行多版本管理,便于切换和设置默认版本。同时,提供常见问题解决方法,如权限错误处理和全局模块迁移方案,以及版本回滚操作,确保用户能够灵活应对不同需求。
502 0
|
6月前
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法
Debian 11更新Node.js主要就是这三种方式,无论你是初涉其中的新手还是找寻挑战的专家,总有一种方式能满足你的需求。现在,你已经是这个
586 80
|
6月前
|
前端开发
个人征信PDF无痕修改软件,个人征信模板可编辑,个人征信报告p图神器【js+html+css仅供学习用途】
这是一款信用知识学习系统,旨在帮助用户了解征信基本概念、信用评分计算原理及信用行为影响。系统通过模拟数据生成信用报告,涵盖还款记录
|
8月前
|
编解码 JavaScript 前端开发
【Java进阶】详解JavaScript的BOM(浏览器对象模型)
总的来说,BOM提供了一种方式来与浏览器进行交互。通过BOM,你可以操作窗口、获取URL、操作历史、访问HTML文档、获取浏览器信息和屏幕信息等。虽然BOM并没有正式的标准,但大多数现代浏览器都实现了相似的功能,因此,你可以放心地在你的JavaScript代码中使用BOM。
243 23
|
10月前
|
前端开发 JavaScript
有没有方法可以保证在JavaScript中多个异步操作的执行顺序?
有没有方法可以保证在JavaScript中多个异步操作的执行顺序?
409 58
|
7月前
|
JavaScript 数据可视化 前端开发
three.js简单实现一个3D三角函数学习理解
1.Three.js简介 Three.js是一个基于JavaScript编写的开源3D图形库,利用WebGL技术在网页上渲染3D图形。它提供了许多高级功能,如几何体、纹理、光照、阴影等,以便开发者能够快速地创建复杂且逼真的3D场景。同时,Three.js还具有很好的跨平台和跨浏览器兼容性,让用户无需安装任何插件就可以在现代浏览器上观看3D内容。
235 0
|
8月前
|
JavaScript 前端开发 Java
js 垃圾回收机制的方法
JS回收机制方法讲解

热门文章

最新文章