成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

正則表達式入門實踐(一)

chanthuang / 1272人閱讀

摘要:一前言正則表達式入門實踐系列文章適合熟悉至少使用過正則表達式的同學,在文章開始的時候我們都會帶著問題去思考如何正確應用正則表達式解決出現(xiàn)的問題,在解決問題的過程中增長你的知識,提高你的實踐能力。

一 前言

正則表達式入門實踐系列文章適合熟悉至少使用過正則表達式的同學,在文章開始的時候我們都會帶著問題去思考如何正確應用正則表達式解決出現(xiàn)的問題,在解決問題的過程中增長你的知識,提高你的實踐能力。所以該系列文章是偏實踐的文章,讀者一定要手動編寫正則表達式提高自己的記憶。筆者能力有限,文章有疏漏之處,還請留言指正。

二 正文 1.從一道面試題談正則表達式

問題:正則表達式將阿拉伯數(shù)字每隔三位為一逗號分離
例如:11500000 -> 11,500,000

提示:正則表達式都是從左向右匹配的,而這個問題好像是從右向左的規(guī)則。但是不要忘了JS字符串強大的反轉能力。最重要的是如何正確處理三個數(shù)字一組,零寬項斷言用過嗎?

"11500000".split("").reverse().join("").replace(/(d{3})(?=[^$])/g, "$1,").split("").reverse().join("");
(1). (?=[^$]) 會匹配除字符除末尾所有的位置
(2). /(d{3})(?=[^$])/ 會匹配連續(xù)的三個數(shù)字,并且這三個數(shù)字不能在字符串的末尾
(3)replace(/(d{3})/g, "$1,"),如果字符串長度剛好是三的倍數(shù),那最后三個字符后也會加上逗號。比如 123456789.replace(/(d{3})/g, "$1,"); // 123,456,789,

這里用到的正則表達式就是:

const pattern = /(d{3})(?=[^$])/g;

//千萬不要寫成:
//const pattern = "/(d{3})(?=[^$])/g";
//這樣pattern就不是正則了,而是真正的字符串

正則表達式的創(chuàng)建方式有兩種:

(1)字面量形式,用//包裹著,如上:/(d{3})(?=[^$])/,其中的g代表全局匹配
(2)函數(shù)的形式,如:new RegExp("(d{3})(?=[^$])","g");

(1)與(2)的區(qū)別:

1)最重要的一點,(2)函數(shù)形式第一個參數(shù)是以字符串的形式傳入的,這就為動態(tài)創(chuàng)建正則表達式提供了可能,在標題2中你可以領略到它的威力。
2)利用函數(shù)創(chuàng)建正則表達式的時候要注意一些字符的轉義,比如d,以為我們并不是匹配一個一個d,d要用在一起表示匹配所有的數(shù)字,所以這里的需要轉義,轉義的方式也很簡單,就是加一個""
3)注意它們創(chuàng)建的方式。(2)函數(shù)中的第一個參數(shù)和(1)//里面的內(nèi)容對應,第二個參數(shù)和g修飾符對應。
2.用正則實現(xiàn)lodash.js的_chunk函數(shù)

Example:

_.chunk(["a", "b", "c", "d"], 2);
// => [["a", "b"], ["c", "d"]]
 
_.chunk(["a", "b", "c", "d"], 3);
// => [["a", "b", "c"], ["d"]]

_.chunk函數(shù)傳入兩個參數(shù),根據(jù)第二個size把第一個參數(shù)數(shù)組切分。有沒有覺得這個和1.面試題有點像呢?只不過這里size不一定是3.
傳統(tǒng)的思考方法是:遍歷這個數(shù)組,遞增size,使用slice函數(shù)生成新的數(shù)組返回。

function chunk(array,size){
    const length = array.length;
    const block = Math.floor(length/size);
    console.log(block);
    const extra = length % size;
    const newArray = [];
    const index = 0;
    for(let i=1;i<=block;i++){
        newArray.push(array.slice((i-1)*size,i*size));
    }
    if(extra > 0){//處理末尾不足size的情況
        newArray.push(array.slice(-extra))
    }
    return newArray;
}

那么思考如何用正則來實現(xiàn)呢?根據(jù)1.的正則表達式你能試著寫一下嗎?
思考30秒~~~~~~~~~~~~~~~~~~~~~~~~~~~

其實答案很簡單:

const chunk =(array,size) =>{
    const reg = new RegExp(`(w{${size}})(?=[^$])`,"g");
   return  array.join("").replace(reg,"$1-").split("-");
}

使用函數(shù)的方式創(chuàng)建正則表達式就可以實現(xiàn)。只不過這里使用的是w詳相當于[0-9a-zA-Z].

源碼上的處理兼容了多種可能。
下面附上庫中源碼:

function chunk(array, size) {
  size = Math.max(size, 0)
  const length = array == null ? 0 : array.length
  if (!length || size < 1) {
    return []
  }
  let index = 0
  let resIndex = 0
  const result = new Array(Math.ceil(length / size))

  while (index < length) {
    result[resIndex++] = slice(array, index, (index += size))
  }
  return result
}
3.開啟真正的正則表達式

經(jīng)過兩個問題的引導,我們開始正式的正則表達式學習。
推薦幾篇文章,大家可以先看一下了解正則表達式的基本知識。
參考鏈接:
全面講解:https://segmentfault.com/a/11...

三 后記

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/92396.html

相關文章

  • 正則達式簡單入門 & 實踐

    摘要:說到郵箱格式,我們簡單分析下郵箱的命名方式一般分為三部分郵件地址郵箱域名地址郵件地址部分的規(guī)則如下英文字母數(shù)字下劃線中劃線點舉幾個栗子根據(jù)以上規(guī)則,我們先寫一下郵件地址部分圖示沒什么問題繼續(xù)往下走。 前言 平時的工作中有很多地方都要用到正則表達式,不得不說,正則的表達式非常強大,比如,我們常用的jquery選擇器,非常方便,jquery的源碼中,選擇器部分應用了大量的正則表達式。然而很...

    superw 評論0 收藏0
  • 前端資源系列(4)-前端學習資源分享&前端面試資源匯總

    摘要:特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 本以為自己收藏的站點多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補充。有錯誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應和斧正,會及時更新,平時業(yè)務工作時也會不定期更...

    princekin 評論0 收藏0
  • 正則達式

    摘要:本文內(nèi)容共正則表達式火拼系列正則表達式回溯法原理學習正則表達式,是需要懂點兒匹配原理的。正則表達式迷你書問世了讓幫你生成和解析參數(shù)字符串最全正則表達式總結驗證號手機號中文郵編身份證地址等是正則表達式的縮寫,作用是對字符串執(zhí)行模式匹配。 JS 的正則表達式 正則表達式 一種幾乎可以在所有的程序設計語言里和所有的計算機平臺上使用的文字處理工具。它可以用來查找特定的信息(搜索),也可以用來查...

    bang590 評論0 收藏0
  • 前端文檔收集

    摘要:系列種優(yōu)化頁面加載速度的方法隨筆分類中個最重要的技術點常用整理網(wǎng)頁性能管理詳解離線緩存簡介系列編寫高性能有趣的原生數(shù)組函數(shù)數(shù)據(jù)訪問性能優(yōu)化方案實現(xiàn)的大排序算法一怪對象常用方法函數(shù)收集數(shù)組的操作面向對象和原型繼承中關鍵詞的優(yōu)雅解釋淺談系列 H5系列 10種優(yōu)化頁面加載速度的方法 隨筆分類 - HTML5 HTML5中40個最重要的技術點 常用meta整理 網(wǎng)頁性能管理詳解 HTML5 ...

    jsbintask 評論0 收藏0

發(fā)表評論

0條評論

chanthuang

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<