正則表達(dá)式

題目1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?

        \d : 數(shù)字字符
        \w : 單詞字符,字母、數(shù)字下劃線
        \s : 空白符
[a-zA-Z0-9] :  字母a到z(包含大小寫),數(shù)字0到9
        \b : 單詞邊界
         . :  除了換行和回車之外的任意字符
         * :  出現(xiàn)零次或多次(任意次)
         + :  出現(xiàn)一次或多次(至少一次)
         ? :  出現(xiàn)零次或一次
      x{3} :  對應(yīng)零次或者3次
         ^ :  開頭
         $ :  結(jié)尾

題目2: 寫一個函數(shù)trim(str),去除字符串兩邊的空白字符

function trim(str) {
    return str.replace(/^\s+|\s+$/g, '');
}
str = "     aa bb cc      ";
trim(str);

題目3: 寫一個函數(shù)isEmail(str),判斷用戶輸入的是不是郵箱

function isEmai(str) {
    return  /^(\w+)(\.\w+)*@(\w+)((\.\w+)+)$/.test(str);
}
str = "takb_666.glo@155.com";
isEmai(str);

題目4: 寫一個函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機(jī)號

function isPhoneNum(str) {
    return /^(\+86)?1(3|4|5|7|8)[0-9]\d{8}$/.test(str);
}

題目5: 寫一個函數(shù)isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個字符,只能包括字母、數(shù)字、下劃線)

function isValidUsername(str) {
    return /^\w{6,20}$/.test(str);
}

題目6: 寫一個函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個字符,只包括大寫字母、小寫字母、數(shù)字、下劃線,且至少至少包括兩種)

function isVaildPassword(str) {
    if(str.length < 6 || str.length >20) return false;
    if(/^[A-Z]+$/.test(str)) return false;
    if(/^[a-z]+$/.test(str)) return false;
    if(/^\d+$/.test(str)) return false;
    if(/^_+$/.test(str)) return false;
    return true;
}

題目7: 寫一個正則表達(dá)式,得到如下字符串里所有的顏色

var re = /#[a-f0-9]{6}/gi
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) )  // ['#121212', '#AA00ef']

題目8: 下面代碼輸出什么? 為什么? 改寫代碼,讓其輸出[""hunger"", ""world""].

var str = 'hello  "hunger" , hello "world"';
var pat =  /".*"/g;
str.match(pat);             //貪婪模式從第一個雙引號匹配到最后一個雙引號  輸出[""hunger" , hello "world""]

當(dāng)正則表達(dá)式中包含能接受重復(fù)的限定符時,通常的行為是(在使整個表達(dá)式能得到匹配的前提下)匹配盡可能多的字符。以這個表達(dá)式為例:a.b,它將會匹配最長的以a開始,以b結(jié)束的字符串。如果用它來搜索aabab的話,它會匹配整個字符串a(chǎn)abab。這被稱為貪婪匹配。
有時,我們更需要懶惰匹配,也就是匹配盡可能少的字符。前面給出的限定符都可以被轉(zhuǎn)化為懶惰匹配模式,只要在它后面加上一個問號?。這樣.
?就意味著匹配任意數(shù)量的重復(fù),但是在能使整個匹配成功的前提下使用最少的重復(fù)?,F(xiàn)在看看懶惰版的例子吧:
a.*?b匹配最短的,以a開始,以b結(jié)束的字符串。如果把它應(yīng)用于aabab的話,它會匹配aab(第一到第三個字符)和ab(第四到第五個字符)。

var str = 'hello  "hunger" , hello "world"';
var pat =  /".*?"/g;
str.match(pat);     // 加一個問號? 轉(zhuǎn)化成懶惰模式,盡量匹配少的字符
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容