前言
大家好,我是林三心,在日常開發中,正規表示式
是非常有用的,正規表示式
在每個語言中都是可以使用的,他就跟JSON
一樣,是通用的。在日常開發中,瞭解一些常用的正規表示式
,能大大提高你的工作效率,例如
- 字串的匹配
- 表單項的格式校驗
今天就給大家分享25個開發中常用的正規表示式吧!!!希望大家能提高程式碼效率!!!
1、手機號碼的校驗
const phoneReg = /^[1][3,4,5,6,7,8,9][0-9]{9}$/
const phoneStr1 = '18886233487'
console.log(phoneReg.test(phoneStr1)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const dateStr2 = '2021-10-10 16:'
console.log(dateReg.test(dateStr2)) // false
9、整數的校驗
const intReg = /^[-+]?\d*$/
const intNum1 = 12345
console.log(intReg.test(intNum1)) // true
const 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)) // true
const floatNum2 = 1234.55
console.log(floatReg.test(floatNum2)) // true
const floatNum3 = 1234.555
console.log(floatReg.test(floatNum3)) // false
12、郵政編號的校驗
const postalNoReg = /^\d{6}$/
const postalNoStr1 = '522000'
console.log(postalNoReg.test(postalNoStr1)) // true
const 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)) // true
const 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)) // true
const 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)) // true
const carNoStr2 = '廣東A12345'
console.log(carNoReg.test(carNoStr2)) // false
16、只含字母的字串
const letterReg = /^[a-zA-Z]+$/
const letterStr1 = 'sunshineLin'
console.log(letterReg.test(letterStr1)) // true
const letterStr2 = 'sunshine_Lin'
console.log(letterReg.test(letterStr2)) // false
17、包含中文的字串
const cnReg = /[\u4E00-\u9FA5]/
const cnStr1 = '我是sunshine_Lin,林三心'
console.log(cnReg.test(cnStr1)) // true
const 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)) // true
const 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)) // true
const 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.*?>/ig
const 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 = /<!--(.*?)-->/g
const 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 = /style="[^=>]*"([(\s+\w+=)|>])/g
const htmlStr = '<div style="background:#000;"><span style="color:#fff"></span></div>'
console.log(styleReg.exec(htmlStr))
// [
// 'style="background:#000;">',
// '>',
// index: 5,
// input: '<div style="background:#000;"><span style="color:#fff"></span></div>',
// groups: undefined
// ]
console.log(styleReg.exec(htmlStr))
// [
// 'style="color:#fff">',
// '>',
// index: 36,
// input: '<div style="background:#000;"><span style="color:#fff"></span></div>',
// groups: undefined
// ]
24、匹配html中的顏色
const colorReg = /#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})/g
const htmlStr = '<div style="background:#000;"><span style="color:#fff"></span></div>'
console.log(colorReg.exec(htmlStr))
// [
// '#000',
// '000',
// index: 23,
// input: '<div style="background:#000;"><span style="color:#fff"></span></div>',
// groups: undefined
// ]
console.log(colorReg.exec(htmlStr))
// [
// '#fff',
// 'fff',
// index: 49,
// input: '<div style="background:#000;"><span style="color:#fff"></span></div>',
// groups: undefined
// ]
25、匹配htmlTag(html標籤)
const endReg = /<("[^"]*"|'[^']*'|[^'">])*>/g
const htmlStr = '<div style="background:#000;"><span style="color:#fff"></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))
結語
如果你覺得此文對你有一丁點幫助,點個贊,鼓勵一下林三心哈哈。或者可以加入我的摸魚群
想進學習群,摸魚群,請看我的主頁介紹,我會定時直播模擬面試,簡歷指導,答疑解惑