来源 | http://www.fly63.com/

正则表达式非常有用。正则表达式可用于每种语言。就像 json 一样,它们是通用的。在日常开发中,了解一些常用的正则表达式可以大大提高你的工作效率。

今天,我给大家分享25个常用的正则表达式,希望大家能提高代码效率!

1、手机号码的校验

const phoneReg = /^[1][3,4,5,6,7,8,9][0-9]{9}$/const phoneStr1 = '18886233487'
console.log(phoneReg.test(phoneStr1)) // trueconst phoneStr2 = '17283017203897'
console.log(phoneReg.test(phoneStr2)) // false

2、身份证的校验

const sfzReg = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/const sfzStr1 = '415106199801012130'
console.log(sfzReg.test(sfzStr1)) // trueconst sfzStr2 = '718381298381212183'
console.log(sfzReg.test(sfzStr2)) // false

3、邮箱的校验

const emailReg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/const emailStrWY = '956666@163.com' // 163邮箱
const emailStrQQ = '956666@qq.com' // qq邮箱
console.log(emailReg.test(emailStrWY)) // true
console.log(emailReg.test(emailStrQQ)) // trueconst noEmail = '72873213.com'
console.log(emailReg.test(noEmail)) // false

4、URL的校验

const urlReg = /^((https?|ftp|file):\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/const urlStr1 = 'https://haha.sunshine.com/xxx/xxx'
console.log(urlReg.test(urlStr1)) // trueconst urlStr2 = 'sss://haha.sunshine.com/xxx/xxx'
console.log(urlReg.test(urlStr2)) // false

5、IPv4的校验

const ipv4Reg = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/const ipv4Str1 = '122.12.56.65'
console.log(ipv4Reg.test(ipv4Str1)) // trueconst ipv4Str2 = '122.12.56.655'
console.log(ipv4Reg.test(ipv4Str2)) // false

6、16进制颜色的校验

const color16Reg = /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/const color16Str1 = '#fff'
console.log(color16Reg.test(color16Str1)) // trueconst color16Str2 = '#1234567'
console.log(color16Reg.test(color16Str2)) // false

7、日期 YYYY-MM-DD

const dateReg = /^\d{4}(\-)\d{1,2}\1\d{1,2}$/const dateStr1 = '2021-10-10'
console.log(dateReg.test(dateStr1)) // trueconst dateStr2 = '2021-01-01 1'
console.log(dateReg.test(dateStr2)) // false

8、日期 YYYY-MM-DD hh:mm:ss

const dateReg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/const dateStr1 = '2021-10-10 16:16:16'
console.log(dateReg.test(dateStr1)) // trueconst dateStr2 = '2021-10-10 16:'
console.log(dateReg.test(dateStr2)) // false

9、整数的校验

const intReg = /^[-+]?\d*$/const intNum1 = 12345
console.log(intReg.test(intNum1)) // trueconst intNum2 = 12345.1
console.log(intReg.test(intNum2)) // false

10、小数的校验

const floatReg = /^[-\+]?\d+(\.\d+)?$/const floatNum = 1234.5
console.log(floatReg.test(floatNum)) // true

11、保留n位小数

function checkFloat(n) {return new RegExp(`^([1-9]+[\d]*(.[0-9]{1,${n}})?)$`)
}
// 保留2位小数
const floatReg = checkFloat(2)const floatNum1 = 1234.5
console.log(floatReg.test(floatNum1)) // trueconst floatNum2 = 1234.55
console.log(floatReg.test(floatNum2)) // trueconst floatNum3 = 1234.555
console.log(floatReg.test(floatNum3)) // false

12、邮政编号的校验

const postalNoReg = /^\d{6}$/const postalNoStr1 = '522000'
console.log(postalNoReg.test(postalNoStr1)) // trueconst postalNoStr2 = '5220000'
console.log(postalNoReg.test(postalNoStr2)) // false

13、QQ号的校验

说明:5-11位数字

const qqReg = /^[1-9][0-9]{4,10}$/const qqStr1 = '1915801633'
console.log(qqReg.test(qqStr1)) // trueconst qqStr2 = '191580163333'
console.log(qqReg.test(qqStr2)) // false

14、微信号的校验

说明:6至20位,以字母开头,字母,数字,减号,下划线

const wxReg = /^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$/const wxStr1 = 'linsanxin885577'
console.log(wxReg.test(wxStr1)) // trueconst wxStr2 = '厉害了我的vx'
console.log(wxReg.test(wxStr2)) // false

15、车牌号的校验

const carNoReg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-Z0-9]{4}[A-Z0-9挂学警港澳]{1}$/const carNoStr1 = '粤A12345'
console.log(carNoReg.test(carNoStr1)) // trueconst carNoStr2 = '广东A12345'
console.log(carNoReg.test(carNoStr2)) // false

16、只含字母的字符串

const letterReg = /^[a-zA-Z]+$/const letterStr1 = 'sunshineLin'
console.log(letterReg.test(letterStr1)) // trueconst letterStr2 = 'sunshine_Lin'
console.log(letterReg.test(letterStr2)) // false

17、包含中文的字符串

const cnReg = /[\u4E00-\u9FA5]/const cnStr1 = '我是sunshine_Lin,林三心'
console.log(cnReg.test(cnStr1)) // trueconst cnStr2 = 'sunshine_Lin'
console.log(cnReg.test(cnStr2)) // false

18、密码强度的校验

说明:密码中必须包含字母、数字、特称字符,至少8个字符,最多30个字符

const passwordReg = /(?=.*[0-9])(?=.*[a-zA-Z])(?=.*[^a-zA-Z0-9]).{8,30}/const password1 = 'sunshine_Lin12345..'
console.log(passwordReg.test(password1)) // trueconst password2 = 'sunshineLin12345'
console.log(passwordReg.test(password2)) // false

19、字符串长度n的校验

function checkStrLength(n) {return new RegExp(`^.{${n}}$`)
}// 校验长度为3的字符串
const lengthReg = checkStrLength(3)const str1 = 'hhh'
console.log(lengthReg.test(str1)) // trueconst str2 = 'hhhhh'
console.log(lengthReg.test(str2)) // false

20、文件拓展名的校验

function checkFileName (arr) {arr = arr.map(name => `.${name}`).join('|')return new RegExp(`(${arr})$`)
}const filenameReg = checkFileName(['jpg', 'png', 'txt'])const filename1 = 'sunshine.jpg'
console.log(filenameReg.test(filename1)) // true
const filename2 = 'sunshine.png'
console.log(filenameReg.test(filename2)) // true
const filename3 = 'sunshine.txt'
console.log(filenameReg.test(filename3)) // true
const filename4 = 'sunshine.md'
console.log(filenameReg.test(filename4)) // false

21、匹配img和src

const imgReg = /<img.*?src=[\"|\']?(.*?)[\"|\']?\s.*?>/igconst htmlStr = '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />'console.log(imgReg.exec(htmlStr))
// [
//   '<img src="sunshine.png" />',
//   'sunshine.png',
//   index: 11,
//   input: '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />',
//   groups: undefined
// ]
console.log(imgReg.exec(htmlStr))
// [
//   '<img src="sunshine111.png" />',
//   'sunshine111.png',
//   index: 37,
//   input: '<div></div><img src="sunshine.png" /><img src="sunshine111.png" />',
//   groups: undefined
// ]

22、匹配html中的注释

const noteReg = /<!--(.*?)-->/gconst htmlStr = '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>'console.log(noteReg.exec(htmlStr))
// [
//   '<!--一个div标签-->',
//   '一个div标签',
//   index: 0,
//   input: '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>',
//   groups: undefined
// ]
console.log(noteReg.exec(htmlStr))
// [
//   '<!--一个div标签-->',
//   '一个div标签',
//   index: 27,
//   input: '<!--一个div标签--> <div></div> <!--一个div标签--> <div></div>',
//   groups: undefined
// ]

23、匹配html中的style

const styleReg = /([(\s+\w+=)|>])/gconst htmlStr = '<div><span></span></div>'console.log(styleReg.exec(htmlStr))
// [
//   '>',
//   '>',
//   index: 5,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]
console.log(styleReg.exec(htmlStr))
// [
//   '>',
//   '>',
//   index: 36,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]

24、匹配html中的颜色

const colorReg = /#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})/gconst htmlStr = '<div><span></span></div>'console.log(colorReg.exec(htmlStr))
// [
//   '#000',
//   '000',
//   index: 23,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]
console.log(colorReg.exec(htmlStr))
// [
//   '#fff',
//   'fff',
//   index: 49,
//   input: '<div><span></span></div>',
//   groups: undefined
// ]

25、匹配htmlTag(html标签)

const endReg = /<("[^"]*"|'[^']*'|[^'">])*>/gconst htmlStr = '<div><span></span></div><h1></h1>'console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))
console.log(endReg.exec(htmlStr))

学习更多技能

请点击下方公众号

25个常用的正则表达式汇总相关推荐

  1. JS常用的正则表达式汇总

    目录 常用的正则表达式汇总 1.常用正则 1.1 校验数字的表达式 1.2 校验字符的表达式 1.3 特殊需求表达式 2.JS调用正则表达式示例 3.match和test区别 3.1 test 3.2 ...

  2. PHP常用正则表达式汇总 [复制链接]

    PHP常用正则表达式汇总 [复制链接] 上一主题下一主题   离线我是小猪头 法师 发帖 539 加关注 发消息 只看楼主 倒序阅读 使用道具楼主  发表于: 2011-06-22 更多 - 本帖被 ...

  3. 常用的PHP正则表达式汇总

    原文:常用的PHP正则表达式汇总 PHP中的常用正则表达式集锦: 匹配中文字符的正则表达式: [\u4e00-\u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包 ...

  4. 25个常用Matplotlib图的Python代码,收藏收藏!

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 大家好,小白今天分享给大家25个Matplotlib图的汇总,在数 ...

  5. 收集常用的正则表达式

    收集常用的正则表达式,欢迎补充. 1.匹配IP地址 function isIP(value){return /^((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\ ...

  6. 正则满足中文的顿号_常用的正则表达式、正则表达式之断言

    一.常用的正则表达式: 1.手机号码:/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])d{8}$/ 2.国内电话号码:/d ...

  7. JavaScript一些常用 API整理汇总

    JavaScript一些常用 API整理汇总 Array new Set() 数组去重 const arr = [3,4,4,5,4,6,5,7]; console.log(new Set(arr)) ...

  8. 常用的正则表达式验证类

    搜集的一些常用的正则表达式验证类: using System;  using System.Text.RegularExpressions;    namespace CommonTools  {  ...

  9. 让你瞬间提高工作效率的常用js函数汇总

    让你瞬间提高工作效率的常用js函数汇总(持续更新) 前言 本文总结了项目开发过程中常用的js函数和正则,意在提高大家平时的开发效率,具体内容如下: 常用的正则校验 常用的设备检测方式 常用的日期时间函 ...

  10. 常用的正则表达式格式

    背景:正则表达式使用单个字符串来描述.匹配一系列匹配某个句法规则的字符串.通常我们使用正则表达式用作信息的验证.虽然正则表达式非常繁琐,但是它的功能却是非常的强大.学会之后会让我们的项目中除了提高效率 ...

最新文章

  1. 程序员:我只想买件没有格子的衬衫,怎么就这么难?
  2. SpringBoot之事务管理Transactional
  3. yolov3 anchor 理解
  4. 【问链财经-区块链基础知识系列】 第三十二课 从区块链溯源来看农产品链的设计
  5. Github热榜--《程序员做饭指南》
  6. 兔子吃萝卜的c语言编程,狼追兔子的c语言实现
  7. android system_server中的dump_SystemServer进程
  8. 【CSP201312-2】ISBN号码,字符串,简单模拟
  9. css3兼容IE8的方案 各个ie的hack
  10. 机器人启示录 百度影音_斯皮尔伯格筹备新作 《机器人启示录》有望启动
  11. ROON1.8无法找到asio驱动的解决办法
  12. 剑指Offer对答如流系列 - 剪绳子
  13. 新零售业背景下实体店的经营战略
  14. ABtest用于推荐系统性能衡量
  15. 罗振宇2021“时间的朋友·长大以后”跨年演讲全文无删减整理,核心观点、大纲提炼
  16. 阶段性PJ某软件APK
  17. Android高性能日志模块-Xlog 正篇
  18. Android组件——使用DrawerLayout仿网易新闻v4.4侧滑菜单
  19. excel打开提示不适合这台计算机,《win10提示excle安装》 win10 :Excel文件打不开、显示“此应用无法在你的电脑上运行”怎么办?...
  20. ls: 显示目下的内容及相关属性信息

热门文章

  1. proteus显示隐藏引脚
  2. Android将毫秒转为时分秒
  3. java修改硬盘序列号怎么查_硬盘序列号的查看方法,如果多块硬盘如何查是哪块块的哪块要换掉?...
  4. matlab norm函数使用_matlab中norm函数的用法(图)
  5. 如何获取 Instagram 视频以及图片
  6. Qt echarts 教程(3):qml echarts 的使用方法
  7. 车牌号对应归属地及城市JSON带简码
  8. 计算机网络怎么算默认网关,ip地址子网掩码计算器_默认网关怎么计算_ip 掩码 网关的关系...
  9. 使用VM12虚拟机安装CentOS7
  10. vue移动端可以左右滑动的滑块