js正則格式化日期時(shí)間自動(dòng)補(bǔ)0的兩種解法
背景
時(shí)間日期格式化的需求很常見(jiàn),也有很多工具類(lèi)轉(zhuǎn)換方法,比如需要將2022-3-4這種日期格式轉(zhuǎn)化為2022-03-04,也就是實(shí)現(xiàn)個(gè)位數(shù)月份或天數(shù)日期自動(dòng)前置補(bǔ) 0。用moment.js、dayjs第三方庫(kù)的 API 也很容易做到,這里我們自己實(shí)現(xiàn)一下看看。
解法一
思路:
先來(lái)看看常規(guī)方案。就用這個(gè)2022-3-4日期來(lái)舉例子,我們先根據(jù)-切分字符串,得到一個(gè)數(shù)組,然后分別識(shí)別3、4這種個(gè)位數(shù)日期,<10就前置補(bǔ) 0,否則不操作。
代碼:
function formatDate(str) { // 根據(jù) - 符號(hào)拆分 return str .split("-") .map((item) => { // +item 將item字符串轉(zhuǎn)換為數(shù)字 // 小于10的時(shí)候就補(bǔ)全一個(gè)前綴0 if (+item < 10) { return "0" + +item; } // 大于10的時(shí)候不用補(bǔ)0 return item; }) .join("-"); // 最后重組回來(lái) } // 測(cè)試 formatDate("2022-03-4"); // 輸出 '2022-03-04'
上面這個(gè)方案,只適配了2022-3-4轉(zhuǎn)2022-03-04這種簡(jiǎn)單的轉(zhuǎn)換,更復(fù)雜的日期格式或者日期時(shí)間格式,比如2022-3-4 1:2:3還不能匹配到。 而且,我們這里只識(shí)別了-這一種格式,假如還有2022/3/4、2022.3.4這種寫(xiě)法呢?
解法二
思路:
再來(lái)看看用正則表達(dá)式,用正則表達(dá)式不僅可以簡(jiǎn)化代碼,還能更容易的兼容更多情況。
我們的核心思路是用前瞻后顧來(lái)識(shí)別日期連接符號(hào)中間的數(shù)字,然后判斷數(shù)字是否需要補(bǔ)全 0。寫(xiě)之前,先來(lái)熟悉幾個(gè)正則表達(dá)式的用法。
1、前瞻:(?=),后顧:(?<=),
簡(jiǎn)單來(lái)理解,就是
// 前瞻: A(?=B) //查找B前面的A // 后顧: (?<=B)A //查找B后面的A // 負(fù)前瞻: A(?!B) //查找后面不是B的A // 負(fù)后顧: (?<!B)A //查找前面不是B的A
我們這里可以用來(lái)識(shí)別-、/、.等字符之間的數(shù)字
2、單詞邊界:\b
- 單詞指的是\w可以匹配的字符,即數(shù)字、大小寫(xiě)字母以及下劃線 [0-9a-zA-Z_]
- 邊界 指的是占位的字符左右的間隙位置
我們這里可以用于識(shí)別-到日期開(kāi)始或結(jié)束位置的數(shù)字,比如2022-3-4 1:2:5中,4后面的間隙,1前面的間隙,5后面的間隙,都是單詞邊界
3、replace方法替換匹配的字符串:$&。
匹配到個(gè)位數(shù)數(shù)字之后,還要補(bǔ) 0,$&就是代表匹配到的數(shù)字,用0$&就可以實(shí)現(xiàn)補(bǔ) 0。
代碼:
// 使用$&匹配 function formatDate(str) { /* replace第一個(gè)參數(shù)正則 (?<=\/|-|\.|:|\b)\d{1} 用的是后顧,查找 / 或者 - 或者 . 或者 : 或者 單詞邊界 或者 T 后面的一個(gè)數(shù)字 \d{1}(?=\/|-|\.|:|\b) 用的是前瞻,查找 / 或者 - 或者 . 或者 : 或者 單詞邊界 或者 T 前面的一個(gè)數(shù)字 replace 第二個(gè)參數(shù)"0$&" 匹配到的字符串前置補(bǔ)0 */ return str.replace(/(?<=\/|-|\.|:|\b|T)\d{1}(?=\/|-|\.|:|\b|T)/g, "0$&"); } // 使用$1匹配 function formatDate(str) { /* replace第一個(gè)參數(shù)正則和上面的一樣 replace 第二個(gè)參數(shù)是一個(gè)函數(shù),第一個(gè)入?yún)⒕褪瞧ヅ涞降牡谝粋€(gè)參數(shù),可以在函數(shù)內(nèi)處理補(bǔ)0 */ return str.replace( /(?<=\/|-|\.|:|\b|T)\d{1}(?=\/|-|\.|:|\b|T)/g, function ($1) { return "0" + $1; } ); } // 測(cè)試 formatDate("2022-3-4 1:2:3"); // 輸出 '2022-03-04 01:02:03' formatDate("2022/3/4"); // 輸出 '2022/03/04' formatDate("2022.3.4"); // 輸出 '2022.03.04' formatDate("2020/8/9T1:2:3"); // 輸出 '2020/08/09T01:02:03'
總結(jié)
我們這里只是做了普通字符串的轉(zhuǎn)換,也有些缺點(diǎn)
- 日期校驗(yàn)沒(méi)有內(nèi)置
- 類(lèi)似01/10/07這種簡(jiǎn)寫(xiě)的日期格式也沒(méi)有考慮在內(nèi)
感興趣的朋友可以發(fā)揮下,豐富下我們的轉(zhuǎn)換方法。
參考
相關(guān)文章
微信小程序的數(shù)據(jù)存儲(chǔ)與Django等服務(wù)發(fā)送請(qǐng)求?講解
這篇文章主要為大家介紹了微信小程序的數(shù)據(jù)存儲(chǔ)與Django等服務(wù)發(fā)送請(qǐng)求講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04javascript IFrame 強(qiáng)制刷新代碼
經(jīng)常會(huì)使用多個(gè)iframe來(lái)展示領(lǐng)域模型主子關(guān)系(主/子單),測(cè)試發(fā)現(xiàn)iframe是有cache功能的2009-07-07用canvas 實(shí)現(xiàn)個(gè)圖片三角化(LOW POLY)效果
這篇文章主要介紹了用canvas 實(shí)現(xiàn)個(gè)圖片三角化(LOW POLY)效果 的相關(guān)資料,需要的朋友可以參考下2016-02-02Javascript使用SWFUpload進(jìn)行多文件上傳
本篇文章主要解釋了使用SWFUpload進(jìn)行多文件上傳,這里整理了詳細(xì)的代碼,有需要的可以了解一下。2016-11-11JavaScript運(yùn)動(dòng)框架 多值運(yùn)動(dòng)(四)
這篇文章主要為大家詳細(xì)介紹了JavaScript運(yùn)動(dòng)框架第四部分,多值運(yùn)動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05關(guān)于定制FileField中的上傳文件名稱問(wèn)題
本文通過(guò)實(shí)例代碼給大家介紹了定制FileField中的上傳文件名稱問(wèn)題,感興趣的朋友參考下吧2017-08-08