JavaScript 日期加算技巧
隨著時代的發(fā)展,我們在不斷地優(yōu)化網(wǎng)頁,并增加一些動態(tài)效果。其中日期選取、倒計時等都不少見,而 JavaScript 提供的日期函數(shù)則成為了這一過程的得力工具。本篇文章主要介紹 JavaScript 中日期加算的相關(guān)技巧。
一、基本日期加算方法
在 JavaScript 中,日期的加算需要用到 Date 對象中的 setXXX 方法,其中 XXX 表示需要設(shè)置的部分,例如:setFullYear、setMonth、setDate 等。例如,下面代碼將日期加上固定天數(shù):
var date = new Date(2019, 7, 16); // 創(chuàng)建指定日期對象 date.setDate(date.getDate() + 3); // 加三天 console.log(date.getFullYear() + "-" + (date.getMonth() + 1) + "-" + date.getDate()); //輸出 2019-8-19從上面的例子可以看出,在實際加減時,需要使用到 setDate 方法,并結(jié)合 getXXX 方法,來進(jìn)行加減計算。 二、借助 Moment.js 的日期加算方法 使用 Date 對象進(jìn)行日期加算,實現(xiàn)起來有點復(fù)雜,需要結(jié)合多個 setXXX 方法計算。而 Moment.js 則是一個輕量級的、功能強大、API 非常人性化的 JavaScript 日期處理庫。Moment.js 簡化了日期處理的難度,尤其是對于日期的加減運算,這更是其一大優(yōu)勢。下面是使用 Moment.js 進(jìn)行日期加減的例子:
var now = moment(); // 當(dāng)前時間 var yesterday = now.add(-1, 'days'); // 昨天 var tomorrow = now.add(1, 'days'); // 明天 var twoDaysAgo = now.add(-2, 'days'); // 兩天前 console.log("昨天是:", yesterday.format('YYYY-MM-DD')); // 輸出:昨天是:2021-09-20 console.log("明天是:", tomorrow.format('YYYY-MM-DD')); // 輸出:明天是:2021-09-22 console.log("兩天前是:", twoDaysAgo.format('YYYY-MM-DD')); // 輸出:兩天前是:2021-09-19通過 Moment.js,我們可以通過 add 方法直接對日期進(jìn)行加減運算,而不需要使用 setXXX 方法。同時,Moment.js 支持豐富的格式化選項,可以讓我們方便地輸出需要的日期時間格式。 三、日期字符串轉(zhuǎn)日期對象 當(dāng)我們拿到一個日期字符串時,如何將其轉(zhuǎn)為日期對象,然后再進(jìn)行加減運算呢?JavaScript 中,可以使用 Date.parse 方法將日期字符串轉(zhuǎn)為時間戳,再通過 new Date 方法將時間戳轉(zhuǎn)為日期對象,同樣可以實現(xiàn)日期加減運算。下面是一個示例:
var dateString = '2019-08-16'; var timestamp = Date.parse(dateString); // 將日期字符串轉(zhuǎn)為時間戳 var dateObj = new Date(timestamp); // 將時間戳轉(zhuǎn)為日期對象 dateObj.setDate(dateObj.getDate() + 3); // 日期加三天 console.log(dateObj.getFullYear() + "-" + (dateObj.getMonth() + 1) + "-" + dateObj.getDate()); //輸出 2019-8-19在這個示例中,我們先將日期字符串轉(zhuǎn)為時間戳,然后再將時間戳轉(zhuǎn)為日期對象。此時,使用 setDate 方法就可以進(jìn)行日期加算了。 結(jié)語 通過上面的介紹,相信大家對于 JavaScript 中的日期加算已經(jīng)有了初步的了解。在實際工作中,我們可以根據(jù)需求進(jìn)行選擇,使用 API 豐富的 Moment.js 等第三方庫進(jìn)行日期處理,也可以根據(jù)實際需求,在原生 Date 對象上進(jìn)行加減運算。希望你的 JavaScript 日期加算實現(xiàn)得越來越優(yōu)秀。