JavaScript 19. 正则表达式

文章目录

  • JavaScript 19. 正则表达式
    • 1. 什么是正则表达式
    • 2. 使用字符串方法
      • 2.1 search() 方法
      • 2.2 replace() 方法
    • 3. 正则表达式修饰符
    • 4. 正则表达式模式
    • 5. 使用 test()
      • 5.1 判断输入字符串是否为数字、字母、下划线组成
      • 5.2 判断输入字符串是否全部为字母
      • 5.3 判断输入字符串是否全部为数字
    • 6. 使用 exec()

1. 什么是正则表达式

正则表达式是由一个字符序列形成的搜索模式。

当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。

正则表达式可以是一个简单的字符,或一个更复杂的模式。

正则表达式可用于所有文本搜索和文本替换的操作。
语法

/正则表达式主体/修饰符(可选)

实例:

var patt = /runoob/i

实例解析:

  • /runoob/i 是一个正则表达式。
  • runoob 是一个正则表达式主体 (用于检索)。
  • i 是一个修饰符 (搜索不区分大小写)。

2. 使用字符串方法

在 JavaScript 中,正则表达式通常用于两个字符串方法 : search() 和 replace()。

  • search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
  • replace() 方法用于在字符串中用一些字符串替换另一些字符串,或替换一个与正则表达式匹配的子串。

2.1 search() 方法

使用正则表达式搜索 "Runoob" 字符串,且不区分大小写:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body><p>搜索字符串 "runoob", 并显示匹配的起始位置:</p>
<button onclick="myFunction()">点我</button>
<p id="demo"></p>
<script>
function myFunction() {var str = "Visit Runoob!"; var n = str.search(/Runoob/i);document.getElementById("demo").innerHTML = n;
}
</script></body>
</html>

输出:

2.2 replace() 方法

replace() 方法将接收字符串作为参数:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body><p>替换 "Microsoft" 为 "Runoob" :</p>
<button onclick="myFunction()">点我</button>
<p id="demo">请访问 Microsoft!</p>
<script>
function myFunction() {var str = document.getElementById("demo").innerHTML; var txt = str.replace("Microsoft","Runoob");document.getElementById("demo").innerHTML = txt;
}
</script></body>
</html>

输出:

3. 正则表达式修饰符

修饰符 可以在全局搜索中不区分大小写:

修饰符 描述
i 执行对大小写不敏感的匹配。
g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m 执行多行匹配。

4. 正则表达式模式

方括号用于查找某个范围内的字符:

表达式 描述
[abc] 查找方括号之间的任何字符。
[0-9] 查找任何从 0 至 9 的数字。
(x y)

元字符是拥有特殊含义的字符:

元字符 描述
\d 查找数字。
\s 查找空白字符。
\b 匹配单词边界。
\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

量词:

量词 描述
n+ 匹配任何包含至少一个 n 的字符串。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。

5. 使用 test()

test() 方法是一个正则表达式方法。

test() 方法用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false。

以下实例用于搜索字符串中的字符 “e”:

var patt = /e/;
patt.test("The best things in life are free!");

字符串中含有 “e”,所以该实例输出为:

true

实例:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body><script>
var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free"));
</script></body>
</html>

输出:

true

你可以不用设置正则表达式的变量,以上两行代码可以合并为一行:

/e/.test("The best things in life are free!")

5.1 判断输入字符串是否为数字、字母、下划线组成

function isValid(str) { return /^\w+$/.test(str); }
str = "1234abd__"
document.write(isValid(str));
document.write("<br>");str2 = "$32343#"
document.write(isValid(str2));
document.write("<br>");

输出:

使用正则表达式的方式来判断。true
false

5.2 判断输入字符串是否全部为字母

val = "123456"
var isletter = /^[a-zA-Z]+$/.test(val);
document.write(isletter);
document.write("<br>");val2 = "asaaa"
var isletter2 = /^[a-zA-Z]+$/.test(val2);
document.write(isletter2);

输出:

使用正则表达式的方式来判断。false
true

5.3 判断输入字符串是否全部为数字

val = "123456"
var isnum = /^\d+$/.test(val);
document.write(isnum);
document.write("<br>");val2 = "as123"
var isnum2 = /^\d+$/.test(val2);
document.write(isnum2);

输出:

使用正则表达式的方式来判断。true
false

6. 使用 exec()

exec() 方法是一个正则表达式方法。

exec() 方法用于检索字符串中的正则表达式的匹配。

该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。

以下实例用于搜索字符串中的字母 “e”:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body><script>
var patt1=new RegExp("e");
document.write(patt1.exec("The best things in life are free"));
</script></body>
</html>

输出:

e

完整的 RegExp 对象参考手册,请参考 JavaScript RegExp 参考手册。

JavaScript 19. 正则表达式相关推荐

  1. javascript的正则表达式

    正则表达式中的特殊字符 字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个 ...

  2. JavaScript常用正则表达式收集

    JavaScript常用正则表达式收集 -------------------------------------------------------------------------------- ...

  3. javascript类型系统——正则表达式RegExp类型

    原文:javascript类型系统--正则表达式RegExp类型 × 目录 [1]对象 [2]实例属性 [3]静态属性[4]实例方法 前面的话 前面已经介绍过javascript中正则表达式的基础语法 ...

  4. JavaScript验证正则表达式大全

    JavaScript验证正则表达式大全 匹配中文字符的正则表达式: [u4e00-u9fa5] 匹配双字节字符(包括汉字在内):[^x00-xff] 评注:可以用来计算字符串的长度(一个双字节字符长度 ...

  5. JavaScript学习总结(13)——JavaScript常用正则表达式

    JavaScript常用正则表达式 一.校验数字的js正则表达式 1 数字:^[0-9]*$ 2 n位的数字:^\d{n}$ 3 至少n位的数字:^\d{n,}$ 4 m-n位的数字:^\d{m,n} ...

  6. 【JavaScript】——正则表达式

    什么是正则表达式? 正则表达式是一种通用的工具,在 JavaScript.PHP.Java.Python.C++ 等几乎所有的编程语言中都能使用:但是,不同编程语言对正则表达式语法的支持不尽相同,有的 ...

  7. 详解Javascript中正则表达式的使用

    章节目录 Javascript中正则表达式的使用 String.prototype.search方法 String.prototype.replace方法 String.prototype.split ...

  8. 【JAVASCRIPT】正则表达式用于定义

    正则表达式 正则表达式用于定义一些字符串的规则,计算机可以根据正则表达式,来检查一个字符串是否符合规则,获取将字符串中符合规则的内容提取出来 1.正则对象 语法:var 变量 = new RegExp ...

  9. javascript中正则表达式的基础语法

    前面的话 正则表达式在人们的印象中可能是一堆无法理解的字符,但就是这些符号却实现了字符串的高效操作.通常的情况是,问题本身并不复杂,但没有正则表达式就成了大问题.javascript中的正则表达式作为 ...

最新文章

  1. (转)使用 Spring缓存抽象 支持 EhCache 和 Redis 混合部署
  2. Unity 2D游戏开发教程之精灵的死亡和重生
  3. html 超出部分被遮挡,div被iframe遮住的几种情况及解决方法
  4. ACdream 1431 Sum vs Product
  5. linux文件系统构成部分及磁盘分区要点
  6. 【BZOJ】1706: [usaco2007 Nov]relays 奶牛接力跑
  7. 虚拟机的管理(libvirtd)、移植和快照
  8. C++_类和对象_C++运算符重载_函数调用运算符重载_---C++语言工作笔记060
  9. 虹软人脸识别SDK - Java服务端的那些事
  10. java文档注释加减乘除,java精确的加减乘除
  11. Android Studio搭建Tensorflow Lite项目和加载tflite模型文件
  12. 网络安全实验8 基于网络入侵检测系统
  13. 日立mCA连接服务器显示地址异常,日立电梯Mca的故障代码是什么
  14. 前端小白的挖坑填坑之路。
  15. 记录一次idea因为虚拟内存不足而闪退的经历
  16. python之pexpect模块
  17. 加州房价--决策树与随机森林
  18. 对京东云鼎的学习笔记
  19. 洗手池下水管堵了怎么办
  20. java学习,入门篇-HelloWorld

热门文章

  1. 别说vivo手机不好用了,这4个黑科技实用又贴心,你都用过吗
  2. 计算机输不了用户名文字,为什么我的电脑打不了字?电脑打不出字怎么办?电脑不能打字的原因?...
  3. 网络编程——epoll模型编程
  4. 基于 Spring Boot + Vue 实现的可视化拖拽编辑的大屏项目
  5. 常用快递物流查询接口对接案例
  6. 全球与中国无绳泳池清洁机器人市场发展现状调研与十四五规划建议报告2023-2029年
  7. 算法学习笔记——动态规划:戳气球
  8. linux下MQTT介绍和开发
  9. 异常检测主要方法总结
  10. 收拾收拾` 回家过年