溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JavaScript怎么自定義日期格式器功能

發(fā)布時間:2022-04-28 14:22:52 來源:億速云 閱讀:146 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“JavaScript怎么自定義日期格式器功能”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“JavaScript怎么自定義日期格式器功能”吧!

1、JavaScript的Date對象

const date = new Date();

該Date對象包含一個Number,表示從新紀(jì)元(即1970年1月1日)起經(jīng)過的毫秒數(shù)。你可以將日期字符串傳遞給Date構(gòu)造函數(shù)以創(chuàng)建指定日期的對象:

const date = new Date('Jul 12 2011');

要獲取當(dāng)前年份,可以使用對象的getFullYear()方法。getFullYear()方法在Date構(gòu)造函數(shù)中返回指定日期的年份:

const currentYear = date.getFullYear(); console.log(currentYear); //2020

同樣,有一些方法可以獲取當(dāng)月的當(dāng)前日期和當(dāng)前的月份:

const today = date.getDate(); const currentMonth = date.getMonth() + 1;

該getDate()方法返回每月的當(dāng)前日期(1-31)。使用getMonth()方法返回指定日期的月份,需要注意的一點是,該方法返回0索引值(0-11),其中0表示一月,11表示十二月。因此,加1可以使月份的值標(biāo)準(zhǔn)化。

2、Date now

now()是Date對象的靜態(tài)方法。它以毫秒為單位的值返回,該值表示從紀(jì)元以來所經(jīng)過的時間。你可以將now()方法返回的毫秒數(shù)傳遞給Date構(gòu)造函數(shù)以實例化新Date對象:

const timeElapsed = Date.now(); const today = new Date(timeElapsed);

3、格式化日期

你可以使用Date對象的方法將日期格式化為多種格式(GMT,ISO等)。該toDateString()方法以我們可讀的格式返回日期:

today.toDateString(); // "Sun Jun 16 2020"

toISOString()返回遵循ISO 8601擴(kuò)展格式的日期:

today.toISOString(); // "2020-06-16T08:30:00.000Z"

toUTCString()以UTC時區(qū)格式返回日期:

today.toUTCString(); // "Sat, 16 Jun 2020 08:30:00 GMT"

toLocaleDateString()以地區(qū)區(qū)時的格式返回日期:

today.toLocaleDateString(); // "6/16/2020"

4、自定義日期格式器功能

除了上面提到的格式外,你的應(yīng)用程序可能具有不同的數(shù)據(jù)格式。它可以是yy/dd/mm或yyyy-dd-mm格式,或者類似的格式。為了解決這個問題,最好創(chuàng)建一個可重用的函數(shù),以便可以在多個項目中使用它。因此,接下來,讓我們創(chuàng)建一個實用程序函數(shù),該函數(shù)將以函數(shù)參數(shù)中指定的格式返回日期:

const today = new Date(); function formatDate(date, format) {     // } formatDate(today, 'mm/dd/yy');

你需要使用參數(shù)中傳遞格式字符串中的月份,日期和年份分別替換字符串“ mm”,“ dd”,“ yy”。然后,使用replace(),如下所示的方法:

format.replace('mm', date.getMonth() + 1);

但是,這將導(dǎo)致很多methods連接在一起,并且會讓我們嘗試把函數(shù)變得更靈活更適合我們的項目時產(chǎn)生麻煩:

.replace('yy', date.getFullYear()) .replace('dd', date.getDate());

然后可以使用正則表達(dá)式代替methods來連接methods replace()。首先創(chuàng)建一個對象,該對象將代表子字符串的鍵值對及其各自的值:

const formatMap = {     mm: date.getMonth() + 1,     dd: date.getDate(),     yy: date.getFullYear().toString().slice(-2),     yyyy: date.getFullYear() };

接下來,使用正則表達(dá)式匹配并替換字符串:

formattedDate = format.replace(/mm|dd|yy|yyy/gi, matched => map[matched]);

完整的功能及代碼如下所示:

function formatDate(date, format) {     const map = {         mm: date.getMonth() + 1,         dd: date.getDate(),         yy: date.getFullYear().toString().slice(-2),         yyyy: date.getFullYear()     }       return format.replace(/mm|dd|yy|yyy/gi, matched => map[matched]) }

到此,相信大家對“JavaScript怎么自定義日期格式器功能”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI