正則表達(dá)式介紹:
//正則表達(dá)式不是js中的獨有功能
//其他的一些語言中也有正則的實現(xiàn)方式并徘,當(dāng)我們在查看關(guān)于正則的資料時遣钳,要確定你看的內(nèi)容是不是js所使用的。
//正則表達(dá)式的作用:用于對字符串進(jìn)行操作(匹配麦乞,替換蕴茴,提取)
//正則的使用不僅限于編程中:
//有一天我想要看片了,可能會去一些論壇網(wǎng)站上找資源
//突然我在xxx論壇發(fā)現(xiàn)了一個我心儀已久的種子
//這個大神發(fā)了一個帖子姐直,想要種子的人倦淀,留下你的郵箱
//小明:大神你好,關(guān)注你很久声畏,你共享了很多的內(nèi)容撞叽,我都非常喜歡,么么噠插龄,我得郵箱是xiaoming@163.com
//小紅:前兩天我老公說想看這個片子,我要今天晚上跟他一起看愿棋,我得郵箱是xiaohong@sina.com
//李雷:不廢話,直接六郵箱 lilei@xxx.gov.com.cn
//我:好人一生平安,郵箱是wuyou@qq.com
//如果這個大神會正則表達(dá)式的話均牢,只需要簡單的一行代碼糠雨,即可搞定
正則的聲明方式:
<script>
//正則也是一個對象形式,key誒使用構(gòu)造函數(shù)的聲明方式以及字面量的聲明方式
//1 構(gòu)造函數(shù)聲明方式
var reg = new RegExp("abc");
var reg = new RegExp(/abc/);
//2 字面量(推薦方式)
var reg = /abc/;
</script>
test方法與簡單類的使用:
<script>
//簡單類:可以匹配正則內(nèi)部設(shè)置的所有內(nèi)容
var reg = /abc/;//可以匹配某個內(nèi)部含有abc的字符串,abc必須為整體徘跪,連續(xù)才可以
//正則.test(要驗證的字符串) 返回bool值甘邀,匹配成功返回true,否則返回false
console.log(reg.test("lhugabcidwa"));//true
console.log(reg.test("lhugaibcdwa"));//false
</script>
字符類:
<script>
//字符類的標(biāo)識垮庐,在正則內(nèi)部使用[]標(biāo)識
//[]整體表示一位字符,滿足內(nèi)部的任何一個字符即可
var reg = /[abc]/;//可以匹配含有abc任意一個字符的字符串
console.log(reg.test("ljalubigcliu"));//true
console.log(reg.test("ljbkbluigliu"));//true
console.log(reg.test("ljkaluigliu"));//true
console.log(reg.test("ljkcluigliu"));//true
console.log(reg.test("ljkluigliu"));//false
</script>
反向類:
<script>
//反向類是對字符類功能的擴(kuò)展
//在字符類的[]內(nèi)最開始位置書寫^,表示反向類
//反向類的作用松邪,為可以匹配除[]內(nèi)部字符以外的其他字符
var reg = /[^abc]/;//可以匹配到除abc以外的其他字符
console.log(reg.test("abcabcabcd"));//true
console.log(reg.test("kgukg"));//true
console.log(reg.test("aaaaaaaa"));//false
</script>
范圍類和組合類:
<script>
//范圍類是對字符串功能的擴(kuò)展,可以使用一個范圍表示多種字符
//var reg = /[abcdefghijklmn]/;
//var reg = /[a-n]/;//表示a-n之間的所有小寫字符
//console.log(reg.test("uuuuuauuuuuu"));
//console.log(reg.test("uuuuuopqrstuuuuuu"));
//組合類:對范圍類的擴(kuò)展
//var reg = /[a-z]/;//所有的小寫字符
//var reg = /[A-Z]/;//所有的大寫字符
//var reg = /[0-9]/;//所有的數(shù)字字符
//如果想要同時檢測多種范圍哨查,可以采用自由組合的方式
var reg = /[n-y2-7B-W]/;
</script>
預(yù)定于類:
<script>
//預(yù)定義類:內(nèi)部預(yù)先準(zhǔn)備號的一些匹配方式
console.log(/\d/.test("kudgwaygdi1awud"));
console.log(/\d/.test("kudgwaygdiawud"));
console.log(/\D/.test("1234567890"));
console.log(/\D/.test("123456A7890"));
</script>
或者:
<script>
//|某一個或者另一個
//可以匹配a-e之間的任意一個字符
//單個字符推薦使用字符類
//相當(dāng)于 /[abcde]/;
//var reg = /a|b|c|d|e/;
//如果每個情況的字符數(shù)多余1個,只能使用或者操作
var reg = /ab|bd|io|we|gh/;
</script>
邊界:
<script>
//邊界標(biāo)識1:在正則的最開始位置書寫^
//表示以后面書寫的內(nèi)容為開頭的字符串可以匹配成功
//var reg = /^abc/;
//console.log(reg.test("abcnukfguwadaw"));//true
//console.log(reg.test("hhhabcnukfguwadaw"));//false
//標(biāo)識2:在正則最后位置書寫 $
//表示以$前面的內(nèi)容為結(jié)束的字符串可以匹配成功
//var reg = /abc$/;
//console.log(reg.test("uubuefeabc"));//true
//console.log(reg.test("uubuefeabcmli"));//false
//特殊用法逗抑,如果一個正則中同時使用了^和$,表示嚴(yán)格匹配(必須和內(nèi)部的內(nèi)容完全一致)
var reg = /^abc$/;
console.log(reg.test("abc"));//true
console.log(reg.test("abcabc"));//false
</script>
量詞:
<script>
//使用量詞,可以減少對正則內(nèi)部重復(fù)部分的書寫
//自定義量詞:
//1 {n} 內(nèi)部的數(shù)值表示前面書寫的內(nèi)容重復(fù)多少次
//var reg = /^a{5}$/;
//console.log(reg.test("aaaa"));//false
//console.log(reg.test("aaaaa"));//true
//console.log(reg.test("aaaaaa"));//false
//2 {n,} 需要出現(xiàn)的次數(shù)為至少n次
//var reg = /^a{3,}$/;
//console.log(reg.test("aa"));
//console.log(reg.test("aaa"));
//console.log(reg.test("aaaa"));
//console.log(reg.test("aaaaa"));
//console.log(reg.test("aaaaaa"));
//3 {n,m} 需要出現(xiàn)的次數(shù)為n-m次之間
//var reg = /^a{3,5}$/;
//console.log(reg.test("aa"));
//console.log(reg.test("aaa"));
//console.log(reg.test("aaaa"));
//console.log(reg.test("aaaaa"));
//console.log(reg.test("aaaaaa"));
//預(yù)定義量詞:
//1 * 表示0次或n次 使用方式(某個要匹配的部分可有可無均正確時锋八,使用*)
//var reg = /^a*$/;
//console.log(reg.test(""));
//console.log(reg.test("a"));
//console.log(reg.test("aaaaa"));
//console.log(reg.test("aaaaaaaaaaaaaa"));
//2 + 表示1次或n次 使用方式浙于,某個部分至少出現(xiàn)一次,可以使用+
//var reg = /^a+$/;
//console.log(reg.test(""));
//console.log(reg.test("a"));
//console.log(reg.test("aa"));
//console.log(reg.test("aaaaa"));
//console.log(reg.test("aaaaaaaaaaaaaa"));
//3 ? 表示0次或1次
// var reg = /^a?$/;
// console.log(reg.test(""));
// console.log(reg.test("a"));
// console.log(reg.test("aa"));
// console.log(reg.test("aaaaaa"));
//注意*所指示的部分挟纱,如果需要是整體羞酗,可以添加()
var reg = /^(abc)*$/;
console.log(reg.test("abcabcabc"));//true
console.log(reg.test("abcccccccc"));//false
</script>
其他方法:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>今天天氣不錯</title>
</head>
<body>
<script>
//字符串.replace(要替換的部分,替換為的部分)
//var str = "abacadae";
//console.log(str.replace("a", "z"));
// //參數(shù)1不僅可以為字符串,同樣可以設(shè)置為正則表達(dá)式
// var str = "aAbAacAadAaeA";
//
// //如果希望正則表達(dá)式可以匹配所有滿足條件的結(jié)果紊服,可以使用正則的匹配模式
// //書寫位置為正則后面
// // g - global - 全局匹配
// console.log(str.replace(/a/g, "z"));
//// console.log(str.replace(new RegExp("a","g"), "z"));
//
// // i - ignoreCase 忽略大小寫
// console.log(str.replace(/a/gi, "z"));
//提取操作:
// 字符串.match(正則) 會將匹配到的內(nèi)容提取出來檀轨,并且返回
var str = "小明:大神你好欺嗤,關(guān)注你很久,你共享了很多的內(nèi)容煎饼,我都非常喜歡,么么噠吆玖,我得郵箱是xiaoming@163.com.cn小紅:前兩天我老公說想看這個片子,我要今天晚上跟他一起看,我得郵箱是xiaohong@sina.com李雷:不廢話沾乘,直接六郵箱 lilei@xxx.gov.com我:好人一生平安,郵箱是wuyou@qq.com"
//提取出內(nèi)部的郵箱地址
//console.log(str.match(/\w+@\w+(\.\w+)+/g));
//正則.exec(字符串);
var reg = /(\w+)@\w+(?:\.\w+)+/g;
//使用一個正則同時匹配多次同一字符串,操作會進(jìn)行累計
//分組提韧崃帷:在正則中()不僅可以像以前一樣使用掷匠,還可以進(jìn)行分組,分組后的內(nèi)容會被exec提取出來
//但是如果某一個組的內(nèi)容并不需要提取,可以在這個括號的開始位置讹语,書寫?:
console.log(reg.exec(str));
console.log(reg.exec(str));
console.log(reg.exec(str));
console.log(reg.exec(str));
</script>
</body>
</html>