JavaScript从入门到精通系列第三十一篇:详解JavaScript中的字符串和正则表达式相关的方法

文章目录

知识回顾

1:概念回顾

2:正则表达式字面量

一:字符串中正则表达式方法

1:split

2:search

3:match

4:replace


大神链接:作者有幸结识技术大神孙哥为好友,获益匪浅。现在把孙哥视频分享给大家。

孙哥链接:孙哥个人主页
作者简介:一个颜值99分,只比孙哥差一点的程序员
本专栏简介:话不多说,让我们一起干翻JavaScript

本文章简介:话不多说,让我们讲清楚JavaScript里边的正则表达式

知识回顾

1:概念回顾

正则表达式用于定义一些字符串的规则,计算机可以根据正则表达式检查一个字符串是否符合规则,或者将字符串中符合规则的内容提取出来。

2:正则表达式字面量

语法:var 变量 =/正则表达式/匹配模式;这种方式创建更加简单,使用构造函数创建更加灵活

javascript 复制代码
var reg = new RegExp("正则表达式","匹配模式");

正则表达式的预发是基于构造函数创建,里边需要有两个参数,一个是正则表达式,另外一个是匹配模式。

编写代码:

javascript 复制代码
var reg = new RegExp("a");
console.log(a);

一:字符串中正则表达式方法

1:split

split是String当中的方法,可以将一个字符串拆分为一个数组

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.split("c");
console.log(result);

但是这样玩有点不灵活,写啥按照啥进行拆分。 我们想根据我们任意字母来将字符串进行拆分

我们方法中可以传递一个正则表达式作为一个参数,这样方法将会按照正则表达式去拆分字符串。

证明这件事情:

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.split(/[a-z]/);
console.log(result);

运行结果:

2:search

这个方法可以搜索字符串中是否指定内容

证明这件事情:

javascript 复制代码
var str = "hello abc hello abc";
var result = str.search("abc");
console.log(result);

运行结果:

返回第一次搜索到的结果索引如果没有的话返回-1

他可以接收一个正则表达式作为参数,根据正则表达式作进行检索。

证明这件事情:

搜索我们字符串中是否包含:abc 或者 aec 或者 afc

javascript 复制代码
var str = "hello abc hello aec afc";
var result = str.search(/a[bef]c/);
console.log(result);

运行结果:

3:match

可以根据正则表达式将复合条件的内容提取出来

证明这件事情:

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.match(/[a-z]/);
console.log(result);

运行结果:

计算机比较懒,只找了第一个,我们需要告诉计算机,我们要所有的复合条件的内容,我们需要设置正则表达式进行全局匹配模式。

证明这件事情:

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.match(/[a-z]/g);
console.log(result);

运行结果:

再设置忽略大小写:

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.match(/[a-z]/gi);
console.log(result);

运行结果:

可以为一个正则表达式设置多个匹配模式且顺序无所谓。

这种情况返回的数据是一个数组。

4:replace

可以将字符串中的指定内容替换为新的内容

证明这件事情:

javascript 复制代码
var str = "1a2b3c4d5e6f";
var result = str.replace(/[a-z]/gi,"@_@");
console.log(result);

指的注意的是split这个方法不论是写不写g都会进行全局匹配

相关推荐
2301_781833521 小时前
Python 正则表达式入门教程
开发语言·python·正则表达式
五阿哥永琪5 小时前
正则表达式
数据库·mysql·正则表达式
小森林之主6 小时前
深入正则表达式:核心语法与实战剖析
javascript·python·正则表达式·编程技巧·字符串处理
小森林之主7 小时前
JavaScript 正则表达式:从零开始的实战对比
javascript·正则表达式·前端开发·性能对比·文本处理
不吃土豆的马铃薯7 小时前
C++ 正则表达式入门详解
linux·服务器·网络·数据库·c++·正则表达式
二月夜3 天前
剖析Java正则表达式回溯问题
java·正则表达式
小林ixn4 天前
从拼多多手机号验证到模板引擎:深入正则表达式与 JS 字符串处理
开发语言·javascript·正则表达式
水木流年追梦5 天前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt
水木流年追梦5 天前
大模型入门-大模型优化方法13- MTP 多 token 输出、DCA 双块注意力
人工智能·分布式·算法·正则表达式·prompt
YHHLAI6 天前
[特殊字符] 拼多多大厂笔试题——正则表达式
正则表达式