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>	

目录
相关文章
|
14天前
|
JavaScript 前端开发
JavaScript遍历数组和对象常用方法总结
以上代码展示了数组和对象的多种遍历方法。对于数组,使用了传统的 `for` 循环、`for...in` 和 ES6 的 `for...of` 进行遍历;对于对象,则通过 `for...in`、`Object.keys()`、`Object.values()` 和 `Object.entries()` 来获取键值对。`for...of` 循环适用于遍历具有迭代协议的数据结构,如数组、字符串等,而对象遍历则更多地依赖于 `Object` 方法来获取其属性集合。
JavaScript遍历数组和对象常用方法总结
|
6天前
|
JavaScript
ES6学习(9)js中的new实现
ES6学习(9)js中的new实现
|
15天前
|
存储 安全 JavaScript
云计算浪潮中的网络安全之舵探索Node.js中的异步编程模式
【8月更文挑战第27天】在数字化时代的风帆下,云计算如同一片广阔的海洋,承载着企业与个人的数据梦想。然而,这片海洋并非总是风平浪静。随着网络攻击的波涛汹涌,如何确保航行的安全成为了每一个船员必须面对的挑战。本文将探索云计算环境下的网络安全策略,从云服务的本质出发,深入信息安全的核心,揭示如何在云海中找到安全的灯塔。
|
9天前
|
JavaScript 前端开发
JavaScript基础知识-枚举对象中的属性
关于JavaScript基础知识中如何枚举对象属性的介绍。
17 1
JavaScript基础知识-枚举对象中的属性
|
13天前
|
JavaScript 算法 前端开发
JS算法必备之String常用操作方法
这篇文章详细介绍了JavaScript中字符串的基本操作,包括创建字符串、访问特定字符、字符串的拼接、位置查找、大小写转换、模式匹配、以及字符串的迭代和格式化等方法。
JS算法必备之String常用操作方法
|
15天前
|
JSON 前端开发 JavaScript
|
9天前
|
JavaScript 前端开发
JavaScript基础知识-对象的基本操作
关于JavaScript对象基本操作的基础知识文章。
22 2
|
9天前
|
JavaScript 前端开发
JavaScript基础知识-对象字面量
文章介绍了JavaScript中对象字面量的创建和使用,包括基本语法、属性赋值以及如何在控制台输出对象属性。
19 0
JavaScript基础知识-对象字面量
|
10天前
|
JavaScript 前端开发 API
Javaweb之javascript的BOM对象的详细解析
BOM为Web开发提供了强大的API,允许开发者与浏览器进行深入的交互。合理使用BOM中的对象和方法,可以极大地增强Web应用的功能性和用户体验。需要注意的是,BOM的某些特征可能会在不同浏览器中表现不一致,因此在开发过程中需要进行仔细的测试和兼容性处理。通过掌握BOM,开发者能够制作出更丰富、更动态、更交互性的JavaWeb应用。
11 1
|
13天前
|
JavaScript 前端开发 iOS开发
学习强大的JavaScript一行代码,能够节省你的时间和代码量
这段内容介绍了25个实用的JavaScript一行代码技巧,涵盖复制内容到剪贴板、打乱数组、颜色值转换、计算平均值、检查数字奇偶性、数组去重、对象为空检测、字符串反转、日期计算、首字母大写、生成随机字符串、四舍五入、清除Cookie、检测暗黑模式等,帮助开发者提高效率并简化代码。
16 2