主頁 > 知識庫 > js正則表達式學習筆記

js正則表達式學習筆記

熱門標簽:宿遷智能外呼系統(tǒng)供應商 鄂州人工智能電銷機器人軟件 實用地圖標注app 地圖標注商戶中心要收錢多少 地圖標注字母的軟件 400免費電話去哪申請 菏澤智能ai電銷機器人銷售公司 css百度地圖標注位置顯示 線上教育ai外呼系統(tǒng)

正則表達式:對字符串中的信息實現(xiàn)查找、替換和提取操作。(不支持注釋和空白,必須寫在一行內(nèi))
正則表達式的創(chuàng)建:包含在一對斜杠之間的字符(直接量語法)
例如:

var pattern = /s$/;  // 創(chuàng)建一個正則來匹配所有以字母s結尾的字符串,并賦值給pattern

一 、字符類
將直接量字符單獨放進方括號內(nèi)就組成了字符類。
一個字符類可以匹配它所包含的任意字符。
正則表達式的字符類:
[...]      方括號內(nèi)的任意字符
[^...]    不在方括號內(nèi)的任意字符
.           除換行符和其他Unicode行終止符之外的任意字符
\w        任何ASCII字符組成的單詞 等價于[a-zA-Z0-9]
\W        任何非ASCII字符組成的單詞 等價于[^a-zA-Z0-9]
\s         任何Unicode空白符
\S        任何非Unicode空白符
\d        任何ASCII數(shù)字 等價于[0-9]
\D        任何非ASCII數(shù)字 等價于[^0-9]
[\b]      退格直接量(特例)
例如:/[a,b,c]/       表示和字母a,b,c中的任意一個都匹配
   /[\s\d]/        表示匹配任意空白字符或者數(shù)字

二、重復
用以表示指定字符重復的標記
正則表達式的重復字符語法:
{n,m}      匹配前一項至少n次,但不超過m次
{n,}     匹配前一項n次或者更多次
{n}      匹配前一項n次
      匹配前一項0次或者1次,也就是前一項是可選的,等價于{0,1}
+         匹配前一項1次或多次,等價于{1,}
*          匹配前一項0次或多次,等價于{0,}

例如:/\d{2,4}/     匹配2~4個數(shù)字
   /\w{3}\d/    精確匹配3個單詞和一個可選數(shù)字

三、選擇、分組和引用
匹配程序:從左到右,如果左邊的匹配項匹配了,就自動忽略右邊的匹配項(即使可以產(chǎn)生更好的匹配)
①     |    用于分隔供選擇的字符
   例如: /ab|cd|ef/      可以匹配字符串“ab”,"cd"或者“ef”
       /\d{3}|[a-z]{4}/       匹配3位數(shù)字或四個小寫字母
②  ()
作用一:把單獨項合成子表達式
作用二:在完整的模式中定義子模式
    當一個正則表達式成功的和目標字符串相匹配時,可以從目標字符串中抽出和圓括號中的子模式相匹配的部分。
    例如:
    /[a-z]+\d+/   檢索一個或多個小寫字母后邊跟著一個或多個數(shù)字
    如果我們關心的是每個尾部的數(shù)字,則可以把模式的數(shù)字部分放到括號(/[a-z]+(\d)/),這樣就可以從檢索到的匹配中抽取數(shù)字了
作用三:允許在同一正則表達式的后部引入前面的子表達式
    實現(xiàn)方法:在字符\后加一位或多位數(shù)字(這個數(shù)字指定了帶圓括號的子表達式在正則表達式中的位置)
    例如:\1    引用的是第一個帶圓括號的子表達式
    注: 位置以參與計數(shù)的左括號位置為準;
    正則表達式不允許用雙引號括起的內(nèi)容中有單引號,反之亦然。
總結:
|       選擇,匹配的是該字符左邊的子表達式或右邊的子表達式
(...)      組合,將幾個項組合成一個單元
(...?)    只組合,把項組合到一個單元,但不記憶與該組相匹配的字符
\n        和第n個分組第一次匹配的字符相匹配,組是圓括號中的子表達式,組索引是從左到右的左括號數(shù),(?: 這個形式的分組不參與索引編碼
四、指定匹配的位置:
錨 :
指定匹配發(fā)生的合法位置
^    匹配字符串的開頭
$    匹配字符串的結尾
\b   匹配一個單詞的邊界 (位于\w和\W之間的位置)
\B   匹配非單詞邊界的位置

五、修飾符

修飾符是放在//之外的,不會出現(xiàn)在兩條/線之間
i 不區(qū)分大小寫
g 全局匹配,找到所有匹配,而不是找到第一個之后就停止
m 多行匹配

六、 用于模式匹配的String對象的方法
方法一: search() 檢索與之匹配的位置
參數(shù):一個正則表達式
返回:第一個與之匹配的子串的起始位置,如果找不到匹配的子串,返回-1
例如:

script>
 "javascript".search(/script/i);  //返回值為4  
/script>

注:① 如果search()的參數(shù)不是正則表達式,則會通過RegExp構造函數(shù)將他轉(zhuǎn)換成正則表達式
      ② search()不支持全局檢索
方法二: replace() 執(zhí)行檢索與替換操作
參數(shù):第一個-->正則表達式
   第二個-->要進行替換的字符串(也可是一個函數(shù),該函數(shù)能動態(tài)的計算替換字符串)
注:① 支持g,
    正則表達式中設置了g:所有與模式匹配的子串都將替換成第二個參數(shù)指定的字符串
      正則表達式中沒設置g:只替換所匹配的第一個子串
 ?、?如果第一個參數(shù)不是正則,而是一個字符串時,replace()將直接搜索這個字符串

例如:將所有不區(qū)分大小寫的javascript都替換成大小寫正確的JavaScript

script>
 var str = "javascript,javascript,javascript,javaScript";
 alert(str.replace(/javascript/gi,"JavaScript"));  //JavaScript,JavaScript,JavaScript,JavaScript
/script>

方法三 : match()
參數(shù):正則表達式
返回:由匹配結果組成的數(shù)組
支持g
實例一:

script>
 var math = "1 plus 2 equals 3".match(/\d+/g);
 console.log(math);  // ["1", "2", "3"]
 console.log(typeof math);  //object
/script>  

實例二:

script>
 var math = "1 plus 2 equals 3".match(/\d/);
 console.log(math);  // ["1", index: 0, input: "1 plus 2 equals 3"]
 console.log(typeof math);  //object
/script>

注意:
給字符串的math()傳入一個非全局的正則表達式:
匹配情況:只檢索第一個匹配
返回值:數(shù)組
    數(shù)組第一個元素:所匹配的字符串
    數(shù)組第二個元素:正則表達式中用圓括號括起來的子表達式,返回的數(shù)組有兩個屬性-->index和input

方法四: split()
返回值:數(shù)組
分隔符:split()的參數(shù)
例如:

script>
 var str= "1,2,3,4,5,6,7,8".split(',');
 console.log(str); //["1", "2", "3", "4", "5", "6", "7", "8"]
/script>

參數(shù)是正則表達式時(可以指定分隔符,允許兩邊可以留任意多的空白符)
返回:用以調(diào)用它的字符串拆分為一個子字符串組成的數(shù)組

script>
 var str= "1,2,3,4,5,6,7,8".split(/\s*,\s*/);  //允許兩邊留任意多的空白符
 console.log(str);  //["1", "2", "3", "4", "5", "6", "7", "8"]
/script>

七、RegExp 對象

RegExp()構造函數(shù):
參數(shù):兩個字符串參數(shù)
第一個:正則表達式的主體部分(兩個斜杠之間的文本)
第二個:(可選)指定正則表達式的修飾符(g,i,m這三者或這三者的組合)
注意:無論是字符串直接量還是正則表達式都使用/字符作為轉(zhuǎn)譯字符的前綴
例如:

var zipCode = new RegExp('\\d{5}','g'); //全局匹配字符串中的5個數(shù)字,注意這里是//而不是/

以上就是為大家整理的關于js正則表達式學習筆記,希望對大家學習js正則表達式有所幫助。

您可能感興趣的文章:
  • 正則表達式模式匹配的String方法
  • js 正則表達式學習筆記之匹配字符串
  • JavaScript 通過模式匹配實現(xiàn)重載
  • JavaScript學習筆記整理_用于模式匹配的String方法

標簽:恩施 綿陽 三亞 咸陽 池州 鞍山 六安 梅州

巨人網(wǎng)絡通訊聲明:本文標題《js正則表達式學習筆記》,本文關鍵詞  正則,表達式,學習,筆記,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《js正則表達式學習筆記》相關的同類信息!
  • 本頁收集關于js正則表達式學習筆記的相關信息資訊供網(wǎng)民參考!
  • 推薦文章