这是我的帖子的升级:Jquery add month to date
我需要通过向 n.total bills 添加不同的月份来从开始日期安排发票日期。日期不能是该月的最后一天,而是开始日期,如果该日期对于该月来说太大(2 月 30 日或 11 月 31 日),则减少到该月的最后一天。
第一个日期将是开始日期。 第二个日期是开始日期后 5 个月。 第三个日期是开始日期后一年。 最大发票的第四个日期将每 6 个月一次。
例如: 日期开始: 30/09/2015 最大数量:6
- 发票 1:2015 年 9 月 30 日
- 发票 2:2016 年 2 月 29 日(闰年)
- 发票 3:2016 年 9 月 30 日
- 发票 4:2017 年 3 月 30 日
- 发票 5:2017 年 9 月 30 日
- 发票 6:2018 年 3 月 30 日
另一个例子: 日期开始: 31/08/2018 最大数量:6
- 发票 1:2018 年 8 月 31 日
- 发票 1:2019 年 1 月 31 日
- 发票 1:2019 年 8 月 31 日
- 发票 2:2020 年 2 月 29 日(闰年)
- 发票 3:2020 年 8 月 31 日
- 发票 4:2021 年 2 月 28 日
欢迎提出建议
PS我尝试了两种不同的解决方案 这个http://jsfiddle.net/J3cPD/112/
var dateStart="31-08-2018";
var splitSrt = dateStart.split("-");
var dateSrt = new Date(splitSrt[2], splitSrt[1] - 1, splitSrt[0]);
var nBill=10;
var mthBill=6;
for (var i=1 ; i<=nBill ; i++ ){
if(i===1){
srvDay = new Date(dateSrt.getFullYear(), dateSrt.getMonth(), dateSrt.getDate());
}else if(i===2){
newDate = dateSrt.addMonths(mthBill - 1);
srvDay = new Date(newDate.getFullYear(), newDate.getMonth(), newDate.getDate());
newDate = dateSrt.addMonths(1);
}else if(i<=nBill){
newDate = dateSrt.addMonths(mthBill);
srvDay = new Date(newDate.getFullYear(), newDate.getMonth(), newDate.getDate());
}
srvDay= srvDay.toString('dd-MM-yyyy');
$(".demo").append("<label>"+srvDay+"</label><br>");
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://www.datejs.com/build/date.js" type="text/javascript"></script>
<div class="demo"></div>
还有这个https://jsfiddle.net/hbud1h10/
var dateStart="31-08-2018";
var splitSrt = dateStart.split("-");
var dateSrt = new Date(splitSrt[2], splitSrt[1] - 1, splitSrt[0]);
var currentDay = dateSrt.getDate();
var nBill=10;
var mthBill=6;
for (var i=1 ; i<=nBill ; i++ ){
var currentMonth = dateSrt.getMonth();
if(i===1){
currentMonth=currentMonth;
}else if(i===2){
currentMonth=currentMonth+(mthBill-1);
}else if(i<=nBill){
currentMonth=currentMonth+(mthBill);
}
dateSrt.setMonth(currentMonth, currentDay);
if (dateSrt.getMonth() > currentMonth + 1) dateSrt.setDate(0);
srvDay= dateSrt.toString('dd-MM-yyyy');
$(".demo").append("<label>"+srvDay+"</label><br>");
if(i===2){
dateSrt.setMonth(currentMonth+1, currentDay);
if (dateSrt.getMonth() > currentMonth + 1) dateSrt.setDate(0);
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<div class="demo"></div>
最佳答案
你可以这样做:
function printInterval(startDate, maxInvoice) {
var splitSrt = startDate.split('-');
var dateSrt = new Date(splitSrt[2], splitSrt[1] - 1, splitSrt[0]);
var currentDay = dateSrt.getDate();
var billsCount = 6;
$('.demo').append('<div><b>Start date: ' + startDate + ', Max Invoice: ' + maxInvoice + '</b></div>');
for (var i = 0, j = 0; i < billsCount; i++) {
var newDate = new Date(dateSrt.getTime());
newDate.setMonth(dateSrt.getMonth() + j, currentDay);
if (newDate.getMonth() > (dateSrt.getMonth() + j) % 12) {
newDate.setDate(0);
}
var txtDay = $.datepicker.formatDate('dd-mm-yy', newDate);
$('.demo').append('<div>'+ (i + 1) + '. Invoice ' + (i + 1) + ': ' + txtDay + '</div>');
if (i === 0) {
j += 5;
} else if (i === 1) {
j += 7;
} else {
j += maxInvoice;
}
}
}
printInterval('30-09-2015', 6);
printInterval('31-08-2018', 6);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<div class="demo"></div>
关于javascript - 如何在 for 循环中向日期添加不同的月份?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42416560/