JS基礎(chǔ)-正則表達(dá)式

有關(guān)于正則表達(dá)式的一些題目

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

\d 代表一個(gè)數(shù)字
\w 代表一個(gè)字符(小寫字母/大寫字母/數(shù)字/下劃線)
\s 代表一個(gè)空白字符
[a-zA-Z0-9] 指的是一個(gè)字符,這個(gè)字符可以是這些范圍里的任意一個(gè)
\b 代表單詞邊界
. 代表任意字符,除去換行'\n'和回車'\r'
***** 匹配前面的東西0次或者多次(任意次),如果*****后面沒有?會盡可能多的去匹配
? 0次或一次
{3} 代表3次
^ 如果^不在中括號里就代表以它后面的字符串為開頭,如果放到中括號里面就是取反
$ 表示以$后面的字符串為結(jié)尾

2. 寫一個(gè)函數(shù)trim(str),去除字符串兩邊的空白字符
 <script type="text/javascript">          
   function trim(str){
     return     str.replace(/^\s+|\s+$/g,'')
   }
 </script>
3. 寫一個(gè)函數(shù)isEmail(str),判斷用戶輸入的是不是郵箱
 <script type="text/javascript">
   function isEmail(str){
     var reg=/\w+@.+/
     return reg.test(str)
   }
 </script>
4. 寫一個(gè)函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機(jī)號
 <script type="text/javascript">
   function isPhoneNum(str){
   return /^1\d{10}$/.test(str)
  }
 </script>
5. 寫一個(gè)函數(shù)isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個(gè)字符,只能包括字母、數(shù)字、下劃線)
 <script type="text/javascript">
  function isValidUsername(str){
    var reg=/^\w{6,20}$/
    return reg.test(str)
  }
6.寫一個(gè)函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個(gè)字符,只包括大寫字母、小寫字母、數(shù)字、下劃線,且至少至少包括兩種)
  function isValidPassword(str){
    if(!/^\w{6,20}$/.test(str)) return false
    if(/^[A-Z]{6,20}$/.test(str)) return false
    if(/^[a-z]{6,20}$/.test(str)) return false
    if(/^_{6,20}$/.test(str)) return false

    return true 
   }
7. 寫一個(gè)正則表達(dá)式,得到如下字符串里所有的顏色
 <script type="text/javascript">
   var re = /*正則...*/
   var subj = "color: #121212; background-color: #AA00ef; width: 12px; 
   bad-colors: f#fddee "
   console.log( subj.match(re) )  // ['#121212', '#AA00ef']


  var subj = "color: #121212; background-color: #AA00ef; width: 12px; 
  bad-colors: f#fddee "
  // (?=;) 前瞻
  var colorReg=/#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})(?=;)/g    
  console.log(subj.match(colorReg))
</script>
8.下面代碼輸出什么? 為什么? 改寫代碼,讓其輸出[""hunger"", ""world""].
 <script type="text/javascript">
   var str = 'hello  "hunger" , hello "world"';
   var pat =  /".*"/g;  
   // 輸出 ""hunger" , hello "world""]
   // 原因: 量詞*出現(xiàn)零次或多次(任意次),在默認(rèn)下會最多匹配,是貪婪模式。

   //讓其輸出[""hunger"", ""world""].  切斷貪婪模式即可,
     var pat = /".*?"/g;
     console.log(str.match(pat));
 </script>

本文題文內(nèi)容來自于饑人谷,版權(quán)歸饑人谷_海瀚和饑人谷所有,轉(zhuǎn)載需說明來源

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

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