生成按月递增循环日期

工具方法:
// 日期加法
    DateAdd(strInterval, Number) {
        let dtTmp = this;
        switch (strInterval) {
          case ‘s‘ :return new Date(Date.parse(dtTmp) + (1000 * Number));
          break;
          case ‘n‘ :return new Date(Date.parse(dtTmp) + (60000 * Number));
          break;
          case ‘h‘ :return new Date(Date.parse(dtTmp) + (3600000 * Number));
          break;
          case ‘d‘ :return new Date(Date.parse(dtTmp) + (86400000 * Number));
          break;
          case ‘w‘ :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number));
          break;
          case ‘q‘ :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
          break;
          case ‘m‘ :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
          break;
          case ‘y‘ :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());
          break;
          default: return dtTmp;
        }  

      };
      // 判断某一天是否为该月最后一天
      isMaxDay(){
        let isMaxDay = false;
        let time = new Date(this);
        let month = time.getMonth();
        let nextDay = time.DateAdd(‘d‘,1);
        let nextDayMonth = nextDay.getMonth();
        if(nextDayMonth - month!=0) {
          isMaxDay = true;
        }
        return isMaxDay;

      };
      // 日期减法
      DateSubtract(strInterval, Number) {
        let dtTmp = this;
        switch (strInterval) {
          case ‘s‘ :return new Date(Date.parse(dtTmp) - (1000 * Number));
          break;
          case ‘n‘ :return new Date(Date.parse(dtTmp) - (60000 * Number));
          break;
          case ‘h‘ :return new Date(Date.parse(dtTmp) - (3600000 * Number));
          break;
          case ‘d‘ :return new Date(Date.parse(dtTmp) - (86400000 * Number));
          break;
          case ‘w‘ :return new Date(Date.parse(dtTmp) - ((86400000 * 7) * Number));
          break;
          default: return dtTmp;
        }
      };

逻辑方法:
        pusharr(times,date){
           this.state.arr.push(date);
           // 判断该天是否为改月最后一天,如果是走第一种算法
           if(date.isMaxDay()){
            let nextTime = ‘‘;
            for (let i = 1; i < times; i++) {
              nextTime = date.DateAdd(‘d‘,31);
              let basicM = date.getMonth();
              let nextM = nextTime.getMonth();
              if(nextM - basicM ===2) {
               let nextD = nextTime.getDate();
               nextTime  = nextTime.DateSubtract(‘d‘,nextD);
             }
             date = nextTime;
             this.state.arr.push(nextTime);
             console.log(this.state.arr);
           }
         }
           // 该天不是该月最后一天,走第二种算法
           else {
             let nextTime = ‘‘;
             for (let i = 1; i<times;i++) {
              nextTime = date.DateAdd(‘m‘,i);
              let basicM = date.getMonth();
              let nextM = nextTime.getMonth();
              if (nextM - basicM ===i+1) {
                let nextD = nextTime.getDate();
                nextTime  = nextTime.DateSubtract(‘d‘,nextD);
              } else if (nextM - basicM <=0) {
               times = times -i;
               this.pusharr(times,nextTime);
               break;
             }
             this.state.arr.push(nextTime);
             console.log(this.state.arr);
           }
         }
       },
时间: 2024-12-14 05:25:04

生成按月递增循环日期的相关文章

C# 时间计算 今天、昨天、前天、明天 一个月的开始日期与结束日期

C# 时间计算 今天.昨天.前天.明天 class Program    {        static void Main(string[] args)        {            DateTime dt1=GetTodayZeroTime(DateTime.Now);            Console.WriteLine("今天零点:{0}",dt1.ToString() );            DateTime dt2 = GetYestodayZeroTim

js获取给定月份的N个月后的日期

1.在讲js获取给定月份的N个月后的日期之前,小颖先给大家讲下getFullYear().getYear()的区别. ①getYear() var d = new Date() console.log(d.getYear()); 打印结果为:116 小颖百度了下,js中Date对象getYear()方法和getFullYear()方法区别,比如:JS中Date对象getYear()方法和getFullYear()方法区别发现很多人写的是: 在IE中是可以正确获取年份:2016,但是在FF等浏览器

MySQL 获取某月所有的日期点

1.问题 如题目所说,通过MySQL获取某年某月所有的天数.如获取2014年2月的所有日期. 2.处理过程 2.1 创建一个数字辅助表 CREATE TABLE `nums` ( `key` int(11) NOT NULL, PRIMARY KEY (`key`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='数字辅助表'; 2.2 创建一个存储过程为数字辅助表增加数据 DELIMITER $$ CREATE DEFINER=`root`@`%`

Oracle获取当前日期前一个月的全部日期

当前日期为2018/08/12. 1.获取当前月份的天数: select to_number(to_char(last_day(sysdate),'dd')) from dual 2.获取当前日期前30天的全部日期. select trunc(sysdate-30)+rownum as days from dual connect by rownum<=30; 执行结果如下: 2.获取当前日期前一个月的全部日期.此处的一个月会根据当前月份获取本月的天数,可能是31天.30天或者29天. sele

获取自然月的起始日期和终止日期

获取自然月的起始日期和终止日期, 比如当前为12月5日, 读取10月26日 - 11月25日的数据. import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.util.GregorianCalendar; import java.util.HashMap; import java.util.Ma

生成“年-月-日”形式的日期字符串

function showDate(time){ var date_obj = new Date(time), year, month, date; year = date_obj.getFullYear(); month = String(date_obj.getMonth() + 1).length === 2 ? (date_obj.getMonth() + 1) : "0" + (date_obj.getMonth() + 1); date = String(date_obj.

按年、季度、月分组&amp;&amp;计算日期和时间的函数

Mysql 按年.季度.月分组 按月度分组: select DATE_FORMAT(i.created_at, '%Y-%m月')...................GROUP BY DATE_FORMAT(i.created_at, '%Y-%m')  按季度分组: select CONCAT(YEAR(i.created_at),'_',QUARTER(i.created_at),'Q')....................GROUP BY CONCAT(YEAR(i.created_

9月23日 日期时间选择

<div style="width:600px; height:100px;"> <select id="year"> </select> 年 <select id="month" onchange="FillDay()"> </select> 月 <select id="day"> </select> 日 </div

android 计算所在周所在月的前后日期

效果图: 使用了 一个时间相关的工具类 package com.yqy.yqy_date; import android.util.Log; import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; /** * 时间工具类 * @author YQY * */ public class ToolDateTime {