js如何比較兩個(gè)日期的時(shí)間大小簡單代碼示例
介紹
使用js比較兩個(gè)日期的時(shí)間大小,一般在前臺選擇時(shí)間時(shí)常常使用。比如:結(jié)束時(shí)間不能小于開始時(shí)間,開始時(shí)間不能小于當(dāng)前時(shí)間等。
代碼示例
示例一:開始時(shí)間不能小于當(dāng)前時(shí)間
//開始時(shí)間
var startTime = '2024-04-22'
//當(dāng)前時(shí)間
var currentDate = new Date();
var currentDateStr = currentDate.getFullYear() + '-' + (currentDate.getMonth() + 1) + '-' + currentDate.getDate();
if (new Date(currentDateStr).getTime() > new Date(startTime).getTime()) {
alert('開始時(shí)間不能小于當(dāng)前時(shí)間')
}
示例二:結(jié)束時(shí)間不能小于開始時(shí)間
var startTime = '2024-04-22'
var endTime = '2024-04-21'
if (new Date(startTime).getTime() > new Date(endTime).getTime()) {
alert('結(jié)束時(shí)間不能小于開始時(shí)間')
}
正式環(huán)境中時(shí)間的判斷流程
首先判斷開始、結(jié)束時(shí)間是否為空,不為空再判斷結(jié)束時(shí)間是否小于開始時(shí)間
var startTime = $("#startTime").val()
var endTime = $("#endTime").val()
if(isEmpty(startTime)){
initError('生效時(shí)間不能為空',$('#startTime').next());
flag = false;
}
if(isEmpty(endTime)){
initError('失效時(shí)間不能為空',$('#endTime').next());
flag = false;
}
if(!isEmpty(startTime)&&!isEmpty(endTime)) {
var currentDate = new Date();
var currentDateStr = currentDate.getFullYear() + '-' + (currentDate.getMonth() + 1) + '-' + currentDate.getDate();
if (new Date(currentDateStr).getTime() > new Date(startTime).getTime()) {
initError('生效時(shí)間不能小于當(dāng)前時(shí)間', $('#startTime').next());
flag = false;
}else{
if (new Date(startTime).getTime() > new Date(endTime).getTime()) {
initError('生效時(shí)間不能大于失效時(shí)間', $('#startTime').next());
flag = false;
}
}
}附:js兩個(gè)日期比較相差多少天實(shí)例
首先來分析一個(gè)問題,兩個(gè)日期是什么格式的?假設(shè)是字符串格式:
可能是:2018/04/20,也可能是:2018/04/20 12:00:00
那接下來分情況討論。
首先看看不含時(shí)間部分的日期格式計(jì)算:
var aDate = new Date('2018/04/23'); // 通過日期字符串,初始化第一個(gè)日期對象
var bDate = new Date('2018/04/25'); // 同上,初始化第二個(gè)日期對象
var aDay = 24 * 60 * 60 * 1000; // 完整一天有24小時(shí),將小時(shí)換算成毫秒時(shí)間戳
var diffDay = (bDate - aDate) / aDay; // 計(jì)算間隔天數(shù)(注意日期隱式轉(zhuǎn)換)
console.log(diffDay); // 2,23日-25日間隔2天然后再來看看包含時(shí)間部分的日期格式計(jì)算:
var aDate = new Date('2018/04/23');
var bDate = new Date('2018/04/25 12:00:00'); // 包含時(shí)間的日期字符串
var aDay = 24 * 60 * 60 * 1000;
var diffDay = (bDate - aDate) / aDay;
console.log(diffDay); // 2.5,自然計(jì)算的結(jié)果
console.log(Math.floor(diffDay)); // 2,根據(jù)個(gè)人情況向下取整,整數(shù)天
console.log(Math.ceil(diffDay)); // 3,根據(jù)個(gè)人情況向上取整,整數(shù)天總結(jié)
到此這篇關(guān)于js如何比較兩個(gè)日期的時(shí)間大小的文章就介紹到這了,更多相關(guān)js比較兩個(gè)日期的時(shí)間大小內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何基于js管理大文件上傳及斷點(diǎn)續(xù)傳詳析
文件上傳是 Web 開發(fā)肯定會碰到的問題,而文件夾上傳則更加難,下面這篇文章主要給大家介紹了關(guān)于如何基于js管理大文件上傳及斷點(diǎn)續(xù)傳的相關(guān)資料,需要的朋友可以參考下2021-08-08
JavaScript中EventBus實(shí)現(xiàn)對象之間通信
這篇文章主要介紹了JavaScript中EventBus實(shí)現(xiàn)對象之間通信,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
js動態(tài)生成Html元素實(shí)現(xiàn)Post操作(createElement)
這篇文章主要介紹了js動態(tài)生成Html元素實(shí)現(xiàn)Post操作(createElement),需要的朋友可以參考下2015-09-09
javascript中bind函數(shù)的作用實(shí)例介紹
bind()的方法在ie,6,7,8中不適用,需要擴(kuò)展通過擴(kuò)展Function prototype可以實(shí)現(xiàn)此方法,下面為大家介紹下javascript中bind函數(shù)的作用2014-09-09

