提前谢谢你的帮助。我试图用moment.js计算两个日期之间的持续时间,但是我不知道当它在我们的营业/开放时间内时,如何只计算时间(在我们的例子中是分钟)。
鉴于这些营业时间:
简单持续时间示例
如果工作于下午4:00开始,周五上午9:30结束,则持续时间为210分钟(下午4-6点= 120分钟,8-9:30 A= 90分钟)。
不那么简单的持续时间示例
如果工作于下午4:00开始,周六上午9:30结束,则持续时间为720分钟(下午4-6点= 120分钟,8a-6p = 600分钟,周五6p到Sat 10a之间的时间不增加持续时间)。
发布于 2018-04-26 17:42:47
现在有一个图书馆就是为了解决这个问题而建的。https://www.npmjs.com/package/moment-business-time。
我相信像下面这样的例子会对你有用。
moment('2015-02-27T16:30:00Z').workingDiff(moment('2015-02-26T12:00:00Z'), 'hours');
// 12
moment('2015-02-27T16:30:00Z').workingDiff(moment('2015-02-26T12:00:00Z'), 'hours', true);
// 12.5
发布于 2018-04-26 19:41:13
正如Cruril所指出的,有一个处理这个问题的库叫做瞬间-商务时间,它是一个用于Moment.js的插件。
问题是您不能在浏览器中运行插件,因为它是一个Node包。我冒昧地提取了脚本,以避免所有讨厌的需要逻辑。有一张使用构建客户端脚本使用褐化的开放票证。
我记录了构建客户端脚本这里的步骤,但编译后的脚本仍然找不到workingDiff
函数。因此,我在下面的脚本中包括了一个简化的即时商务时间版本。
moment.updateLocale('en', {
workinghours: {
0: null, // Sun : CLOSED
1: [ '12:00:00', '20:00:00' ], // Mon : 8am - 4pm (local EDT)
2: [ '12:00:00', '18:00:00' ], // Tue : 8am - 2pm (local EDT)
3: [ '12:00:00', '20:00:00' ], // Wed : 8am - 4pm (local EDT)
4: [ '12:00:00', '18:00:00' ], // Thu : 8am - 2pm (local EDT)
5: [ '12:00:00', '16:00:00' ], // Fri : 8am - 12pm (local EDT)
6: null // Sat : CLOSED
},
holidays : []
});
moment.locale('en');
moment.tz.setDefault("America/New_York"); // Timezone plugin
var dateFormat = 'MM/DD/YYYY hh:mm:ss a';
// 0 + 8 + 6 + 8 + 6 + (4 - 1.5) + 0 = 30.5
var fromDate = moment('04/01/2018 00:00:00 am', dateFormat); // 2018-04-01T04:00:00.000Z
var toDate = moment('04/06/2018 02:30:00 pm', dateFormat); // 2018-04-06T18:30:00.000Z
console.log(fromDate.workingDiff(toDate, 'hours')); // 30 hours
console.log(fromDate.workingDiff(toDate, 'hours', true)); // 30.5 hours
.as-console-wrapper { top: 0; max-height: 100% !important; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.1/moment.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.16/moment-timezone.min.js"></script>
<script src="https://rawgit.com/rmkane/32084550b349eaebe7e78e46903084ce/raw/434cf510165a65c234a8cb1cb99641bc7ab15c16/moment-business-time.js"></script>
<!--
https://github.com/lennym/moment-business-time
https://www.npmjs.com/package/moment-business-days#how-to-use
-->
发布于 2018-04-27 15:13:55
一般情况下,不要在没有展示你目前的情况的情况下发布一个问题。要求免费工作是不受欢迎的。话虽如此,但我也不认为,如果你是相对绿色的话,仅仅使用一个库就一定是走的路。你只有通过编码才能变得更好。
我写了一个快速的未完成的证明,以获得分钟利用的时刻。如果这是用于生产代码--不要使用它,这是一个示例,供您查看并了解如何处理解决方案。(有很多)。
试着查看代码,然后编写自己的实现。
function isOutOfTimeRange(time, start, end) {
var date = time.format('YYYY-MM-DD');
var startDate = date + ' ' + start;
var endDate = date + ' ' + end;
if (!time.isBetween(startDate, endDate, 'minute')) {
var timeFormatted = time.format('YYYY-MM-DD HH:mm');
// If the time is exactly start or end time it should be ok to use
if ((timeFormatted === startDate) || (timeFormatted === endDate)) {
return false;
}
return true;
}
return false;
}
function isOutOfHours(time, businessHrs) {
var day = time.day();
var dayStart = businessHrs[day].start;
var dayEnd = businessHrs[day].end;
return isOutOfTimeRange(time, dayStart, dayEnd);
}
function getMinsWorked(startTime, endTime) {
return moment.duration(endTime.diff(startTime)).as('minutes');
}
function minutesWorked(startJob, endJob, bizHrs) {
var start = moment(startJob);
var end = moment(endJob);
// return early if the start and end time range is invalid
if (end.isBefore(start, 'second')) {
return 'A job cannot start after it has ended!';
}
// return early if start or end is not within business hours
if (isOutOfHours(start, bizHrs) || isOutOfHours(end, bizHrs)) {
console.log('The start and end date must not be out of hours');
}
var timeDiff = moment.duration(end.diff(start));
var firstDay = start.day();
var lastDay = end.day();
// return early if we can make a quick calculation on the same day
if (firstDay === lastDay) {
// create a duration object by diffing the end and start dates and return as minutes
return timeDiff.as('minutes');
}
var totalMinsWorked = 0;
var endTime;
var startTime;
for (var i = firstDay; i <= lastDay; ++i) {
var currentDay = start.add(i - firstDay, 'days');
var dateStr = currentDay.format('YYYY-MM-DD');
var dayStart = moment(dateStr + ' ' + bizHrs[i].start);
var dayEnd = moment(dateStr + ' ' + bizHrs[i].end);
// it's the last day so diff the end time from the start
if (i === lastDay) {
totalMinsWorked += getMinsWorked(dayStart, end);
}
// it's the first day so go from the start time
if (i === firstDay) {
totalMinsWorked += getMinsWorked(start, dayEnd);
}
// its a centre day so just get the dif of the start to the end
totalMinsWorked += getMinsWorked(dayStart, dayEnd);
}
return totalMinsWorked;
}
console.log(minutesWorked('2018-05-16 10:00', '2018-05-16 12:30', [{ // index 0 is Sunday
start: '10:00',
end: '14:00'
},
{
start: '08:00',
end: '18:00'
},
{
start: '08:00',
end: '18:00'
},
{
start: '08:00',
end: '18:00'
},
{
start: '08:00',
end: '18:00'
},
{
start: '08:00',
end: '18:00'
},
{ // index 6 is Sat
start: '10:00',
end: '14:00'
}
]));
<script src="https://momentjs.com/downloads/moment.js"></script>
https://stackoverflow.com/questions/50048813
复制相似问题