摘要:和區別當采用非全局匹配的時候,兩個方法的返回值完全一樣。和都只匹配一次,且都會把分組抽出來放到數組后面當為全局匹配的時候,方法返回一個存放所有匹配內容的數組無視子表達式的匹配。
exec()和match()區別
當采用非全局匹配的時候,兩個方法的返回值完全一樣。
match和exec都只匹配一次,且都會把分組抽出來放到數組后面
(function(){ let str="antzoane"; let reg=/(a)(n)/; console.log(str.match(reg)); console.log(reg.exec(str)); })();
當為全局匹配的時候,match方法返回一個存放所有匹配內容的數組(無視子表達式的匹配)。
exex方法返回數組不會存儲所有的匹配,僅存儲第一個匹配到的內容(存儲在數字第一個元素),第二個元素存儲第一個子表達式匹配到的內容,第三個元素存儲第二個子表達式匹配到的內容,以此類推
(function(){ let str="antzoane"; let reg=/a(n)/g; console.log(str.match(reg)); console.log(reg.exec(str)); //再次調用從上次的lastindex開始匹配; console.log(reg.exec(str)); })();match()和分組匹配
var reg = /(d{4})-(d{2})-(d{2})/; var dateStr = "2018-04-18"; var s=dateStr.match(reg); console.log(s)//arr[0]是匹配的結果,arr[1]是第一個()里的匹配內容,全局匹配不會返回()里的內容 var str="hello my name is ben ,this is "; var reg2=/ {1,}/g; var reg22=/( ){1,}/g//()內看成一個整體去匹配 console.log(str.match(reg2)); console.log(str.match(reg22));replace()和分組捕獲 全部匹配添加修飾
var str="0816-2323263"; var reg=/(d+)(-)(d+)/g; var str2=str.replace(reg,"($1)-$3");//全部匹配添加修飾 console.log(str2);//(0816)-2323263(?
var str1="123478basd-12aaaaa"; var reg1=/(d+)([a-z]+)(d+)(?匹配需要刪除的部分然后置空[a-z]+)/g; var str21=str1.replace(reg1,"$1hhhhh$ ");//(? )捕獲文本到名稱為name的組里 (?:exp)匹配exp,不捕獲匹配的文本,也不給此分組分配組號 console.log(str21);//123478basd-12aaaaa
var str23="123478basd12asdsa"; var reg2=/[a-z]+/g; var str22=str23.replace(reg2,"");//匹配需要刪除的部分然后置空 console.log(str22);//12347812貪婪與懶惰
在量詞后面加個問號表示懶惰,盡可能少的匹配
var str="abc8defghij7klngon8qrstwxy7"; var reg1=/8[a-zA-Z0-9]*7/; var reg2=/8[a-zA-Z0-9]*?7/; var reg3=/8[a-zA-Z0-9]+?/; var res1=str.match(reg1); var res2=str.match(reg2); var res3=str.match(reg3); console.log(res1); console.log(res2); console.log(res3);零寬斷言
(?=exp)向前查找
(?<=exp)向后查找
(?!exp)匹配后面跟的不是exp的位置
(?
(function(){ var str="http://www.sina.com.cn "; var reg1= new RegExp(/.+(:)/g); var res1=str.match(reg1); var reg2=new RegExp(/.+(?=:)/); var res2=str.match(reg2); console.log(res1); console.log(res2); })();
(function(){ var a = "價格是123456789.6754"; var reg4= new RegExp(/(d)(?=(d{3})+.)/g); console.log(a.match(reg4)); var b = a.replace(reg4, "$1,"); console.log(b) })();
(function(){ let str="ABCD01:$23.45"; let reg1=/$[0-9.]+/g; let reg2=/(?<=$)[0-9.]+/g; let res1=str.match(reg1); let res2=str.match(reg2); console.log(res1); console.log(res2); })();匹配固定位數
匹配固定位數時,不能/[1-9]d{4,11}/這樣寫,這樣輸入15位也會從15位中成功匹配11位
只能用^和$匹配字符串開始和結束位置,然后再匹配中間的位數(^$不是從哪里開始匹配
function check(val) { console.log(val) var reg = /^[1-9]d{4,8}[0-9]$/;//匹配5到10位qq號 if (!reg.test(val)) { alert("輸入有誤"); }else{ alert("輸入正確"); } }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/105209.html
摘要:和區別當采用非全局匹配的時候,兩個方法的返回值完全一樣。和都只匹配一次,且都會把分組抽出來放到數組后面當為全局匹配的時候,方法返回一個存放所有匹配內容的數組無視子表達式的匹配。 exec()和match()區別 當采用非全局匹配的時候,兩個方法的返回值完全一樣。 match和exec都只匹配一次,且都會把分組抽出來放到數組后面 (function(){ ...
摘要:返回值返回值根據傳入的參數類型和規則的不同,返回的內容不同,但總體來說,它是返回一個對象,而不是索引,如果沒匹配到任何符合條件的字符串,則返回。 本文發布在我的博客一道小小的題目引發對javascript支持正則表達式相關方法的探討許可協議: 署名-非商業性使用-禁止演繹 4.0 國際 轉載請保留原文鏈接及作者。 以前對于正則是非常懼怕的,因為看不懂和學不會。但最近項目中頻繁的...
摘要:基礎語法鞏固正則表達式引擎根據正則去匹配字符的時候,是通過檢查索引的方式。妻原配就是好,可以直接使用正則表達式調用它。下面解釋一下上面這些常用的元字符查找單個字符,除了換行和行結束符。正則系列文章整理到了 上一章內容:正則表達式實戰篇 知識回顧 前2章分別學習了正則表達式入門技巧,以及遇到正則需求該如何去分析問題,還有正則表達式實戰的一些場景解釋。 這一章內容偏向理論,推薦你點擊開頭的...
閱讀 2809·2021-10-26 09:48
閱讀 1671·2021-09-22 15:22
閱讀 4028·2021-09-22 15:05
閱讀 608·2021-09-06 15:02
閱讀 2607·2019-08-30 15:52
閱讀 2107·2019-08-29 18:38
閱讀 2755·2019-08-28 18:05
閱讀 2332·2019-08-26 13:55