js正則格式化日期時間自動補(bǔ)0的兩種解法
背景
時間日期格式化的需求很常見,也有很多工具類轉(zhuǎn)換方法,比如需要將2022-3-4這種日期格式轉(zhuǎn)化為2022-03-04,也就是實(shí)現(xiàn)個位數(shù)月份或天數(shù)日期自動前置補(bǔ) 0。用moment.js、dayjs第三方庫的 API 也很容易做到,這里我們自己實(shí)現(xiàn)一下看看。
解法一
思路:
先來看看常規(guī)方案。就用這個2022-3-4日期來舉例子,我們先根據(jù)-切分字符串,得到一個數(shù)組,然后分別識別3、4這種個位數(shù)日期,<10就前置補(bǔ) 0,否則不操作。
代碼:
function formatDate(str) {
// 根據(jù) - 符號拆分
return str
.split("-")
.map((item) => {
// +item 將item字符串轉(zhuǎn)換為數(shù)字
// 小于10的時候就補(bǔ)全一個前綴0
if (+item < 10) {
return "0" + +item;
}
// 大于10的時候不用補(bǔ)0
return item;
})
.join("-"); // 最后重組回來
}
// 測試
formatDate("2022-03-4"); // 輸出 '2022-03-04'
上面這個方案,只適配了2022-3-4轉(zhuǎn)2022-03-04這種簡單的轉(zhuǎn)換,更復(fù)雜的日期格式或者日期時間格式,比如2022-3-4 1:2:3還不能匹配到。 而且,我們這里只識別了-這一種格式,假如還有2022/3/4、2022.3.4這種寫法呢?
解法二
思路:
再來看看用正則表達(dá)式,用正則表達(dá)式不僅可以簡化代碼,還能更容易的兼容更多情況。
我們的核心思路是用前瞻后顧來識別日期連接符號中間的數(shù)字,然后判斷數(shù)字是否需要補(bǔ)全 0。寫之前,先來熟悉幾個正則表達(dá)式的用法。
1、前瞻:(?=),后顧:(?<=),
簡單來理解,就是
// 前瞻: A(?=B) //查找B前面的A // 后顧: (?<=B)A //查找B后面的A // 負(fù)前瞻: A(?!B) //查找后面不是B的A // 負(fù)后顧: (?<!B)A //查找前面不是B的A
我們這里可以用來識別-、/、.等字符之間的數(shù)字
2、單詞邊界:\b
- 單詞指的是\w可以匹配的字符,即數(shù)字、大小寫字母以及下劃線 [0-9a-zA-Z_]
- 邊界 指的是占位的字符左右的間隙位置
我們這里可以用于識別-到日期開始或結(jié)束位置的數(shù)字,比如2022-3-4 1:2:5中,4后面的間隙,1前面的間隙,5后面的間隙,都是單詞邊界
3、replace方法替換匹配的字符串:$&。
匹配到個位數(shù)數(shù)字之后,還要補(bǔ) 0,$&就是代表匹配到的數(shù)字,用0$&就可以實(shí)現(xiàn)補(bǔ) 0。
代碼:
// 使用$&匹配
function formatDate(str) {
/*
replace第一個參數(shù)正則
(?<=\/|-|\.|:|\b)\d{1} 用的是后顧,查找 / 或者 - 或者 . 或者 : 或者 單詞邊界 或者 T 后面的一個數(shù)字
\d{1}(?=\/|-|\.|:|\b) 用的是前瞻,查找 / 或者 - 或者 . 或者 : 或者 單詞邊界 或者 T 前面的一個數(shù)字
replace 第二個參數(shù)"0$&" 匹配到的字符串前置補(bǔ)0
*/
return str.replace(/(?<=\/|-|\.|:|\b|T)\d{1}(?=\/|-|\.|:|\b|T)/g, "0$&");
}
// 使用$1匹配
function formatDate(str) {
/*
replace第一個參數(shù)正則和上面的一樣
replace 第二個參數(shù)是一個函數(shù),第一個入?yún)⒕褪瞧ヅ涞降牡谝粋€參數(shù),可以在函數(shù)內(nèi)處理補(bǔ)0
*/
return str.replace(
/(?<=\/|-|\.|:|\b|T)\d{1}(?=\/|-|\.|:|\b|T)/g,
function ($1) {
return "0" + $1;
}
);
}
// 測試
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)沒有內(nèi)置
- 類似01/10/07這種簡寫的日期格式也沒有考慮在內(nèi)
感興趣的朋友可以發(fā)揮下,豐富下我們的轉(zhuǎn)換方法。
參考
相關(guān)文章
javascript檢查表單數(shù)據(jù)是否改變的方法
需要檢查用戶是否修改了一個表單中的內(nèi)容,可以使用本文提供的方法,如果修改了表單的內(nèi)容則返回true,沒修改則返回false,有需求的朋友可以參考下2013-07-07
使用uniapp實(shí)現(xiàn)發(fā)布朋友圈功能
這篇文章主要介紹了使用uniapp實(shí)現(xiàn)發(fā)布朋友圈功能,在文章底部給大家介紹了uniapp?微信小程序分享、分享朋友圈功能,通過頁內(nèi)自定義分享按鈕,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
js實(shí)現(xiàn)鼠標(biāo)懸停圖片上時滾動文字說明的方法
這篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)懸停圖片上時滾動文字說明的方法,涉及js操作鼠標(biāo)事件的使用技巧,需要的朋友可以參考下2015-02-02
淺談js使用in和hasOwnProperty獲取對象屬性的區(qū)別
下面小編就為大家?guī)硪黄獪\談js使用in和hasOwnProperty獲取對象屬性的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
通過JS解決頁面刷新導(dǎo)致按鈕OnClientClick事件消失問題
這篇文章主要介紹了如何通過JS解決頁面刷新導(dǎo)致按鈕OnClientClick事件消失問題,OnClientClick 提供客戶端JS執(zhí)行能力,并以 return false 或 return true 來決定是否繼續(xù)執(zhí)行 OnClick 事件,需要的朋友可以參考下2024-12-12
改進(jìn) JavaScript 和 Rust 的互操作性并深入認(rèn)識 wasm-bindgen 組件
這篇文章主要介紹了改進(jìn) JavaScript 和 Rust 的互操作性并深入認(rèn)識 wasm-bindgen 組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07

