a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Regex > 正文

JavaScript 正則表達式備忘單實例代碼

2020-03-16 20:45:26
字體:
來源:轉載
供稿:網友

正則表達式或“regex”用于匹配字符串的各個部分 下面是我創(chuàng)建正則表達式的備忘單。

匹配正則

使用 .test() 方法

let testString = "My test string";let testRegex = /string/;testRegex.test(testString);

匹配多個模式

使用操作符號 |

const regex = /yes|no|maybe/; 

忽略大小寫

使用i標志表示忽略大小寫

const caseInsensitiveRegex = /ignore case/i;const testString = 'We use the i flag to iGnOrE CasE';caseInsensitiveRegex.test(testString); // true

提取變量的第一個匹配項

使用 .match() 方法

const match = "Hello World!".match(/hello/i); // "Hello"

提取數(shù)組中的所有匹配項

使用 g 標志

const testString = "Repeat repeat rePeAT";const regexWithAllMatches = /Repeat/gi;testString.match(regexWithAllMatches); // ["Repeat", "repeat", "rePeAT"] 

匹配任意字符

使用通配符. 作為任何字符的占位符

// To match "cat", "BAT", "fAT", "mat"const regexWithWildcard = /.at/gi;const testString = "cat BAT cupcake fAT mat dog";const allMatchingWords = testString.match(regexWithWildcard); // ["cat", "BAT", "fAT", "mat"] 

用多種可能性匹配單個字符

  • 使用字符類,你可以使用它來定義要匹配的一組字符
  • 把它們放在方括號里 []
//匹配 "cat" "fat" and "mat" 但不匹配 "bat"const regexWithCharClass = /[cfm]at/g;const testString = "cat fat bat mat";const allMatchingWords = testString.match(regexWithCharClass); // ["cat", "fat", "mat"] 

匹配字母表中的字母

使用字符集內的范圍 [a-z]

const regexWidthCharRange = /[a-e]at/;const regexWithCharRange = /[a-e]at/;const catString = "cat";const batString = "bat";const fatString = "fat";regexWithCharRange.test(catString); // trueregexWithCharRange.test(batString); // trueregexWithCharRange.test(fatString); // false

匹配特定的數(shù)字和字母

你還可以使用連字符來匹配數(shù)字

const regexWithLetterAndNumberRange = /[a-z0-9]/ig;const testString = "Emma19382";testString.match(regexWithLetterAndNumberRange) // true

匹配單個未知字符

要匹配您不想擁有的一組字符,使用否定字符集 ^

const allCharsNotVowels = /[^aeiou]/gi;const allCharsNotVowelsOrNumbers = /[^aeiou0-9]/gi; 

匹配一行中出現(xiàn)一次或多次的字符

使用 + 標志

const oneOrMoreAsRegex = /a+/gi;const oneOrMoreSsRegex = /s+/gi;const cityInFlorida = "Tallahassee";cityInFlorida.match(oneOrMoreAsRegex); // ['a', 'a', 'a'];cityInFlorida.match(oneOrMoreSsRegex); // ['ss']; 

匹配連續(xù)出現(xiàn)零次或多次的字符

使用星號 *

const zeroOrMoreOsRegex = /hi*/gi;const normalHi = "hi";const happyHi = "hiiiiii";const twoHis = "hiihii";const bye = "bye";normalHi.match(zeroOrMoreOsRegex); // ["hi"]happyHi.match(zeroOrMoreOsRegex); // ["hiiiiii"]twoHis.match(zeroOrMoreOsRegex); // ["hii", "hii"]bye.match(zeroOrMoreOsRegex); // null

惰性匹配

  • 字符串中與給定要求匹配的最小部分
  • 默認情況下,正則表達式是貪婪的(匹配滿足給定要求的字符串的最長部分)
  • 使用 ? 阻止貪婪模式(惰性匹配 )
 const testString = "catastrophe"; const greedyRexex = /c[a-z]*t/gi; const lazyRegex = /c[a-z]*?t/gi; testString.match(greedyRexex); // ["catast"] testString.match(lazyRegex); // ["cat"] 

匹配起始字符串模式

要測試字符串開頭的字符匹配,請使用插入符號^,但要放大開頭,不要放到字符集中

const emmaAtFrontOfString = "Emma likes cats a lot.";const emmaNotAtFrontOfString = "The cats Emma likes are fluffy.";const startingStringRegex = /^Emma/;startingStringRegex.test(emmaAtFrontOfString); // truestartingStringRegex.test(emmaNotAtFrontOfString); // false 

匹配結束字符串模式

使用 $ 來判斷字符串是否是以規(guī)定的字符結尾

const emmaAtBackOfString = "The cats do not like Emma";const emmaNotAtBackOfString = "Emma loves the cats";const startingStringRegex = /Emma$/;startingStringRegex.test(emmaAtBackOfString); // truestartingStringRegex.test(emmaNotAtBackOfString); // false 

匹配所有字母和數(shù)字

使用/word 簡寫

const longHand = /[A-Za-z0-9_]+/;const shortHand = //w+/;const numbers = "42";const myFavoriteColor = "magenta";longHand.test(numbers); // trueshortHand.test(numbers); // truelongHand.test(myFavoriteColor); // trueshortHand.test(myFavoriteColor); // true

除了字母和數(shù)字,其他的都要匹配

用/W 表示 /w 的反義

const noAlphaNumericCharRegex = //W/gi;const weirdCharacters = "!_$!!";const alphaNumericCharacters = "ab283AD";noAlphaNumericCharRegex.test(weirdCharacters); // truenoAlphaNumericCharRegex.test(alphaNumericCharacters); // false

匹配所有數(shù)字

你可以使用字符集[0-9],或者使用簡寫 /d

const digitsRegex = //d/g;const stringWithDigits = "My cat eats $20.00 worth of food a week.";stringWithDigits.match(digitsRegex); // ["2", "0", "0", "0"]

匹配所有非數(shù)字

用/D 表示 /d 的反義

 

const nonDigitsRegex = //D/g;const stringWithLetters = "101 degrees";stringWithLetters.match(nonDigitsRegex); // [" ", "d", "e", "g", "r", "e", "e", "s"]

匹配空格

使用 /s 來匹配空格和回車符

const sentenceWithWhitespace = "I like cats!"var spaceRegex = //s/g;whiteSpace.match(sentenceWithWhitespace); // [" ", " "]

匹配非空格

用/S 表示 /s 的反義

const sentenceWithWhitespace = "C a t"const nonWhiteSpaceRegex = //S/g;sentenceWithWhitespace.match(nonWhiteSpaceRegex); // ["C", "a", "t"]

匹配的字符數(shù)

你可以使用 {下界,上界} 指定一行中的特定字符數(shù)

const regularHi = "hi";const mediocreHi = "hiii";const superExcitedHey = "heeeeyyyyy!!!";const excitedRegex = /hi{1,4}/;excitedRegex.test(regularHi); // trueexcitedRegex.test(mediocreHi); // trueexcitedRegex.test(superExcitedHey); //false

匹配最低個數(shù)的字符數(shù)

使用{下界, }定義最少數(shù)量的字符要求,下面示例表示字母 i 至少要出現(xiàn)2次

const regularHi = "hi";const mediocreHi = "hiii";const superExcitedHey = "heeeeyyyyy!!!";const excitedRegex = /hi{2,}/;excitedRegex.test(regularHi); // falseexcitedRegex.test(mediocreHi); // trueexcitedRegex.test(superExcitedHey); //false

匹配精確的字符數(shù)

使用{requiredCount}指定字符要求的確切數(shù)量

const regularHi = "hi";const bestHi = "hii";const mediocreHi = "hiii";const excitedRegex = /hi{2}/;excitedRegex.test(regularHi); // falseexcitedRegex.test(bestHi); // trueexcitedRegex.test(mediocreHi); //false

匹配0次或1次

使用 ? 匹配字符 0 次或1次

const britishSpelling = "colour";const americanSpelling = "Color";const languageRegex = /colou?r/i;languageRegex.test(britishSpelling); // truelanguageRegex.test(americanSpelling); // true

代碼部署后可能存在的BUG沒法實時知道,事后為了解決這些BUG,花了大量的時間進行l(wèi)og 調試,這邊順便給大家推薦一個好用的BUG監(jiān)控工具 Fundebug

總結

以上所述是小編給大家介紹的JavaScript  正則表達式備忘單實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!


注:相關教程知識閱讀請移步到正則表達式頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 97超碰超碰 | 国产欧美精品在线 | 特一级黄色片 | 黄色在线观看 | 国产乱肥老妇国产一区二 | 日韩欧美视频 | 国产第一毛片 | 久久久久久高清 | 久久久成人网 | 国产精品一区二区在线免费观看 | 色视频免费看 | 一级电影院 | 九色精品 | 成人黄色在线视频 | 在线天堂av | 蜜桃久久久久久 | 亚洲精品一区二区三区蜜桃久 | 在线99视频 | 黄色视频a级毛片 | 欧美日韩精品在线观看 | 在线观看免费视频亚洲 | 天堂一区二区三区 | 国产区视频在线 | 99久久99热这里只有精品 | 日本视频在线播放 | 亚洲午夜精品一区二区三区他趣 | 中文字幕亚洲视频 | 人人鲁人人莫一区二区三区 | 久久99精品久久久 | 日日摸日日碰夜夜爽不卡dvd | 香蕉久久久久久 | 一级a性色生活片久久毛片明星 | 免费av毛片 | 亚洲精品久久 | 国产福利在线观看视频 | 日干夜干天天干 | 五月伊人亚洲精品一区 | 性色视频在线观看 | 91久久久久久久久 | 亚洲国产字幕 | 国产精品人人做人人爽 |