【Web APIs】正则表达式

目录

1.正则表达式

2.正则表达式语法

3.元字符

3.1边界符 

3.2量词 

3.3字符类 

4.修饰符


1.正则表达式

正则表达式(Regular Expression)是用于匹配字符串中字符组合的模式,在 JavaScript中,正则表达式也是对象。通常用来查找、替换那些符合正则表达式的文本,许多语言都支持正则表达式。

使用场景:

  • 验证表单:用户名表单只能输入英文字母、数字或者下划线, 昵称输入框中可以输入中文(匹配)
  • 过滤掉页面内容中的一些敏感词(替换)
  • 从字符串中获取我们想要的特定部分(提取) 

2.正则表达式语法

定义正则表达式语法:

①定义规则

  • let 变量名 = /表达式/   比如let reg = /前端/
  • 其中/ /是正则表达式字面量

②查找

🔷判断是否有符合规则的字符串

  • test()方法 用来查看正则表达式与指定字符串是否匹配
  • 语法:regObj.test(被检测的字符串)
  • 找到返回true,没找到返回false

🔷检索(查找)符合规则的字符串

  • exec()方法 在一个指定字符串中执行一个搜索匹配
  • 语法:regObj.exec(被检测的字符串)
  • 如果匹配成功,exec()方法返回一个数组,否则返回null

3.元字符

普通字符:

仅能够描述它们本身,例如所有的字母和数字。也就是说普通字符只能够匹配字符串中与它们相同的字符。

元字符(特殊字符)

是一些具有特殊含义的字符,可以极大提高了灵活性和强大的匹配功能。

比如,规定用户只能输入英文26个英文字母

  • 普通字符写法: abcdefghijklm…..
  • 元字符写法: [a-z]  

参考文档:

正则测试工具: http://tool.oschina.net/regex 

元字符分类:

  1. 边界符(表示位置,开头和结尾,必须用什么开头,用什么结尾)
  2. 量词 (表示重复次数)
  3. 字符类 (比如 \d  表示 0~9)

3.1边界符 

边界符:用来提示字符所处的位置,主要有两个字符

📖Note:

  • 如果 ^ 和 $ 在一起,表示必须是精确匹配

3.2量词 

量词:用来设定某个模式出现的次数

📖Note:

  • 逗号左右两侧千万不要出现空格 

3.3字符类 

字符类:

① [ ]  匹配字符集合:后面的字符串只要包含 abc 中任意一个字符,都返回 true 。


 [ ]  里面加上 - 连字符

  • [a-z]  表示 a 到 z 26个英文字母都可以
  • [a-zA-Z]   表示大小写都可以
  • [0-9]  表示 0~9 的数字都可以

量词就近原则:只和最近的字符集合匹配

^[1-9][0-9]{4,}$   //其中的量词{4,}表示的是[0-9]出现的次数大于等于4

案例:表单验证

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.error {color: red;}.right {color: green;}</style></head>
<body><input type="text"><span></span><script>let input = document.querySelector('input')let span = input.nextElementSibling// 监听事件 失去焦点input.addEventListener('blur', function() {if(/^[a-zA-Z0-9-_]{6,16}$/.test(input.value)) {// 合法span.className = 'right'span.innerHTML = '输入正确'} else {// 非法// className会覆盖span.className = 'error'span.innerHTML = '只能输入6~16位的字符'}})</script>
</body>
</html>

③[ ]  里面加上 ^ 取反符号

  • [^a-z] 匹配除了小写字母以外的字符
  • 注意要写到中括号里面

④ . 匹配除换行符之外的任何单个字符

预定义:指的是某些常见模式的简写方式

4.修饰符

修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等

语法:/表达式/修饰符

  • i 是单词 ignore 的缩写,正则匹配时字母不区分大小写
  • g 是单词 global 的缩写,匹配所有满足正则表达式的结果

replace 替换

  • 字符串.replace(/正则表达式/,替换的文本)

案例:替换敏感词

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><textarea name="" id="" cols="30" rows="10"></textarea><button>发布</button><div></div><script>let btn = document.querySelector('button')let textarea = document.querySelector('textarea')let div = document.querySelector('div')// 按钮监听事件btn.addEventListener('click', function() {div.innerHTML = textarea.value.replace(/的/g, '*')// 过滤用户输入内容})</script>
</body>
</html>

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

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

相关文章

主流公链 - Solana

探索Solana区块链&#xff1a;下一代高性能区块链平台 1. Solana简介 Solana是一个高性能的区块链平台&#xff08;TPS能达到10W级别&#xff09;&#xff0c;旨在实现高吞吐量和低延迟的区块链交易处理。它采用了一系列创新技术&#xff0c;其中包括Proof of History (PoH)&a…

管理能力学习笔记三:管理者的时间管理法

时间管理三步法 1、对任务进行分类 2、估算任务时间 3、持续反思评估 对任务进行分类 分类方法&#xff1a;时间管理四象限 A类 B类 C类 D类 估算时间 需要预留休息时间和机动时间 持续反思评估 核对检查任务 自我提问 处理日常干扰的办法 对事情发出提问 对话内容进行…

华为云服务器租用价格_云服务器优惠活动_2024年新版报价

2024年华为云服务器租用价格表&#xff0c;云服务器优惠价格35元一年&#xff0c;配置为1核2G1M带宽HECS云服务器、L实例-2核2G3M配置46元1年、4核16G10M华为云服务器24元一个月、2核4G5M服务器158元一年&#xff0c;3年1010元、华为云香港服务器99元一年、增强型C7云服务器4核…

P1036 [NOIP2002 普及组] 选数

思路&#xff1a;也算典型的dfs&#xff0c;题目就是要求从n个数中选择k个数&#xff0c;计算这k个数的和&#xff0c;看这个和是否是素数。我们知道在dfs时相当于是进行全排列&#xff0c;而结果要求的是组合后和的情况。根据排列和组合的关系&#xff0c;他们之间差K&#xf…

压测利器Webbench(附源码)

web压力测试工具webbench介绍 webbench最多可以模拟3万个并发连接去测试网站的负载能力&#xff0c;并发能力比较高&#xff0c;可以测试https及动态静态页面。 核心原理 父进程fork若干个子进程&#xff0c;每个子进程在用户要求时间或默认的时间内对目标web循环发出实际访问…

C#打印50*30条码标签

示例图&#xff1a; 源码下载地址&#xff1a;https://download.csdn.net/download/tiegenZ/89035407?spm1001.2014.3001.5503

01背包和完全背包

文章目录 01背包1、01背包暴力解法&#xff0c;回溯问题2、动态规划解法3、01背包代码优化 完全背包1、完全背包模型 GitHub参考链接 01背包 1、01背包暴力解法&#xff0c;回溯问题 #include<bits/stdc.h> using namespace std; const int N 1e25; int w[N],v[N]; i…

ValueError: Cannot load file containing pickled data when allow_pickle=False

问题描述 遇到报错&#xff1a;ValueError: Cannot load file containing pickled data when allow_pickleFalse 解决方案 经过查阅有人说是与numpy的版本有关&#xff0c;但是还是不要轻易改变环境中的版本&#xff0c;不一定哪个地方就会报错。这里放个解决方案&#xff1a;…

C++生成动态连接库

文章目录 一、静态连接与动态连接二、 动态链接库&#xff08;DLL&#xff09;的创建三、dll库的使用四、 动态链接链接库工作原理五、extern "C" 一、静态连接与动态连接 静态库和动态库区别是库的加载时间不同。静态库&#xff1a;在链接阶段库将会与.o目标文件一起…

YOLO中的预训练模型是否需要

这张图片显示的是使用YOLOv5&#xff08;一种流行的物体检测算法&#xff09;进行训练时的一段命令行指令以及对应的注释&#xff0c;这些注释是中文的。这里列出的是两个不同情况下的命令行用法。 上面的命令&#xff1a; python train.py --data custom.yaml --weights yolo…

C++中的凸包:convexHull使用手册【c++重要方法】

最近工作中&#xff0c;用到了凸包&#xff0c;查了一些资料&#xff0c;差不多搞明白了&#xff0c;在这里做一个总结&#xff0c;希望可以帮助到你&#xff01; 什么时候需要它&#xff1f; 如果你想要把一群散落的点&#xff0c;包裹起来。而且希望这个包裹尽可能地紧凑&a…

MQTT.fx和MQTTX 链接ONENET物联网提示账户或者密码错误

参考MQTT.fx和MQTTX 链接ONENET物联网开发平台避坑细节干货。_mqttx和mqttfx-CSDN博客 在输入password和username后还是提示错误&#xff0c;是因为在使用token的时候&#xff0c;key填写错误&#xff0c;将设备的密钥填入key中

How to convert .py to .ipynb in Ubuntu 22.04

How to convert .py to .ipynb in Ubuntu 22.04 jupyter nbconvertp2j 最近看到大家在用jupyter notebook&#xff0c;我也试了一下&#xff0c;感觉还不错&#xff0c;不过&#xff0c;也遇到了一些问题&#xff0c;比方说&#xff0c;我有堆的.py文件&#xff0c;如果要一个一…

赛氪网亮相中国人工智能产业发展联盟会议,共筑赛事生态新篇章

2024年3月14日至15日&#xff0c;备受瞩目的中国人工智能产业发展联盟&#xff08;AIIA&#xff09;第十一次全体会议在海南海口盛大召开。作为人工智能领域的重要交流与合作平台&#xff0c;此次会议吸引了300余位联盟成员单位代表齐聚一堂&#xff0c;共襄盛举。在这场人工智…

NIO与AIO

NIO与AIO NIO模型 在 LInux 环境中&#xff0c;java.nio.channels.Selector 的子类叫做 sun.nio.ch.EPollSelectorImpl &#xff0c;其底 层是基于 Epoll 模型去实现的 IO 多路复用器。 对于 Epoll 模型 我们需要了解到它底层的三个函数 在 JDK 实现的底层中&#xff0c;EPol…

某对象存储元数据集群改造流水账

软件产品&#xff1a;某厂商提供的不便具名的对象存储产品&#xff0c;核心底层技术源自HDFS和Amazon S3&#xff0c;元数据集群采用了基于MongoDB的NOSQL数据库产品和MySQL数据库产品相结合。 该产品的元数据逻辑示意图如下&#xff1a; 业务集群现状&#xff1a;当前第3期建…

勾八头歌之分类回归聚类

一、机器学习概述 第1关机器学习概述 B AD B BC 第2关常见分类算法 #编码方式encodingutf8from sklearn.neighbors import KNeighborsClassifierdef knn(train_data,train_label,test_data):input:train_data用来训练的数据train_label用来训练的标签test_data用来测试的数据…

【Monero】Onion Monero Blockchain Explorer | 洋葱门罗币区块链浏览器

github&#xff1a;onion-monero-blockchain-explorer Onion Monero Blockchain Explorer特点: • 没有cookie&#xff0c;没有网络分析跟踪器&#xff0c;没有image&#xff0c; • 开源&#xff0c; • 完全用C编写&#xff0c; • 显示加密的付款 ID&#xff0c; • 显示环…

Django auth模块

【一】命令行创建用户 【1】语法 python manage.py createsuper【2】示例 用户名 默认是是电脑名称 邮箱 可以填也可以不填 密码 terminal中&#xff1a;输入密码不显示出来manage.py中&#xff1a;明文输入输入密码太简单会提示 Username (leave blank to use administra…