js以当前时间为基础,便捷获取时间(最近2天,最近1周,最近2周,最近1月,最近2月,最近半年,最近一年,本周,本月,本年)
在开发公司管理后台系统时,遇到了需要根据不同的时间段如“近一年、近半年、近三月、近一月、近一周”来获取并展示不同图表数据的需求,很是繁琐,项目开发周期又非常的短,自己想了一下,虽然有思路,但一时半会儿要写出来还是比较费时的,所以就索性上网找一个现成的轮子吧,还好已有大神写过同样的效果的,但离我实际的需求还是有点远,现在先参考大神的代码来做一个笔记吧:
//格式化时间
function formatTime(param) {
  let y = param.getFullYear();
  let m = param.getMonth() + 1;
  let d = param.getDate();
  m = m < 10 ? ("0" + m) : m;
  d = d < 10 ? ("0" + d) : d;
  return y + "-" + m + "-" + d + " ";
}
/**
* 以当前时间为基础,便捷获取时间(最近2天,最近1周,最近2周,最近1月,最近2月,最近半年,最近一年,本周,本月,本年)
* @param { string } code
* @returns { Object }
*/
function getDate(code) {
  const date = new Date();
  let endTime = formatTime(date);
  let date1 = Date.parse(date);
  let start = '';
  let end = '';
  let oneDay = 1000 * 3600 * 24;
  switch (code) {
    //今天
    case 'today':
      start = new Date();
      break;
    //最近2天
    case 'lastTwoDay':
      start = date1 - oneDay * 2;
      break;
    //最近1周
    case 'lastOneWeek':
      start = date1 - oneDay * 7;
      break;
    //最近2周
    case 'lastTwoWeek':
      start = date1 - oneDay * 14;
      break;
    //最近1月
    case 'lastOneMonth':
      start = new Date();
      start.setMonth(start.getMonth() - 1)
      break;
    //最近2月
    case 'lastTwoMonth':
      start = new Date();
      start.setMonth(start.getMonth() - 2)
      break;
    //最近3月
    case 'lastThreeMonth':
      start = new Date();
      start.setMonth(start.getMonth() - 3)
      break;
    //最近半年
    case 'lastHalfYear':
      start = date1 - oneDay * 183;
      break;
    //最近一年
    case 'lastOneYear':
      start = new Date();
      start.setYear(start.getFullYear() - 1)
      break;
    //本周
    case 'thisWeek':
      let a = 6 - date.getDay();
      start = new Date(date1 - oneDay * a).setHours(0, 0, 0, 0);
      end = new Date(date1 + oneDay * (1 + date.getDay())).setHours(24, 0, 0, 0)
      break;
    //本月
    case 'thisMonth':
      start = new Date();
      start.setHours(0, 0, 0, 0)
      start.setMonth(start.getMonth(), 1)
      end = new Date(start)
      end.setHours(0, 0, 0, 0)
      end.setMonth(start.getMonth() + 1, 1)
      break;
    //本年
    case 'thisYear':
      start = new Date();
      start.setHours(0, 0, 0, 0)
      start.setMonth(0, 1)
      start.setYear(start.getFullYear())
      end = new Date(start)
      end.setHours(0, 0, 0, 0)
      end.setMonth(start.getMonth(), 1)
      end.setYear(start.getFullYear() + 1)
      break;
  }
  return {
    startTime: formatTime(new Date(start)),
    endTime: end ? formatTime(new Date(end)) : endTime,
  }
}
使用方法很简单,输出最近一周:console.log(getDate('lastOneWeek'))。
这种方法出来的效果如最近一周:{startTime: "2019-09-22 ", endTime: "2019-09-29 "},这样的处理适合那种只需要一个开始日期和结束日期的接口,而根据我们的实际需求,需要的是类似这样的数据:
最近一周:["2019-09-22", "2019-09-23", "2019-09-24", "2019-09-25", "2019-09-26", "2019-09-27", "2019-09-28", "2019-09-29"]或者最近一月:["2019-08-29", "2019-08-30", "2019-08-31", "2019-09-01", ..., "2019-09-29"]。
因为这个需求是用在类似折线图表这样的X轴做展示用的,如图:

是不是很繁琐?让前端处理起来,相当麻烦,写后台接口的同事说你们前端别处理了,太麻烦了,这个日期我们来返给你们。真是良心啊!!!
本文参考:https://www.cnblogs.com/qinacao/p/9117514.html
js以当前时间为基础,便捷获取时间(最近2天,最近1周,最近2周,最近1月,最近2月,最近半年,最近一年,本周,本月,本年)的更多相关文章
- js设置本周 本月 本年
		
var SetSearchDate = function (sign, sid, eid) {//sign 标识符区分本周本月本年,sid开始时间id,eid结束时间id var now = new ...
 - Js:消息弹出框、获取时间区间、时间格式、easyui datebox 自定义校验、表单数据转化json、控制两个日期不能只填一个
		
(function ($) { $.messageBox = function (message) { $.messager.show({ title:'消息框提示', msg:message, sh ...
 - Mysql自动设置时间(自动获取时间,填充时间)
		
应用场景: 1.在数据表中,要记录每条数据是什么时候创建的,不需要应用程序去特意记录,而由数据数据库获取当前时间自动记录创建时间: 2.在数据库中,要记录每条数据是什么时候修改的,不需要应用程序去特意 ...
 - Mysql设置创建时间字段和更新时间字段自动获取时间,填充时间
		
1.引言在实际开发中,每条数据的创建时间和修改时间,尽量不需要应用程序去记录,而由数据库获取当前时间自动记录创建时间,获取当前时间自动记录修改时间. 2.创建语句(1)–添加CreateTime 设置 ...
 - Mysql数据库存储数据时间与系统获取时间不一致
		
最近进行项目开发,发现存在数据库内的数据和系统查询到的数据相差8小时 发现有2种比较合适的方法 (一)修改mysql服务的区时 centos进入mysql查看/修改时区 1.输入以下命令进入mysql ...
 - moment.js获取本周本月本年的开始日期和结束日期
		
//获取本日 const startDate = moment().format('YYYY-MM-DD'); const startDate = moment().format('YYYY-MM-D ...
 - JAVA获取本周 本月 本年 第一天和最后一天
		
/** * 日期工具类 */ public class DateUtils { /** * 获取今天 * @return String * */ public static String getTod ...
 - js获取时间加多山天和时间戳转换成日期
		
function huoqu(){ var data = $("#data").val();//获取的时间 var day = $('#day').val();//往后 ...
 - javaScript系列:js中获取时间new Date()详细介绍
		
var myDate = new Date();myDate.getYear(); //获取当前年份(2位)myDate.getFullYear(); //获取完整的年份(4位,1970-????)m ...
 
随机推荐
- [转]敏捷开发需求管理(产品backlog)
			
传统的瀑布工作模式使用详细的需求说明书来表达需求,需求人员负责做需求调研,根据调研情况编制详细的需求说明书,进行需求评审,评审之后签字确认交给研发团队设计开发.在这样的环境下,需求文档是信息传递的主体 ...
 - Codeforces Round #167 (Div. 1 + Div. 2)
			
C. Dima and Staircase 线段树维护区间最大值. D. Dima and Two Sequences 由于模数不一定为质数,所以通过拆分质因数来做阶乘取模. E. Dima and ...
 - Python--day34--前面网络编程的复习
 - 模版——KMP
			
#include <iostream> #include <cstdio> #include <cstring> ; int f[maxn]; char P[max ...
 - 关于Character的digit,forDigit,getNumericValue方法的一点理解
			
Character类是一个包装类. char这种数据类型是基于原始的Unicode编码的,储存一个char用16个bit,因此定义characters也是16位定长的实体集合. Unicode编码标准 ...
 - 【mac】关于mac的一些命令
			
一. 如何查看自己的文件大小,所有文件占了多少? du -h -d 1 . 当前目录文件以及大小 sudo du -h -d 1 / 所目录下的文件以及大小
 - linux /proc 接口
			
无论何时一个硬件中断到达处理器, 一个内部的计数器递增, 提供了一个方法来检查设备 是否如希望地工作. 报告的中断显示在 /proc/interrupts. 下面的快照取自一个双处理 器 Pentiu ...
 - 搭建zookeeper出现错误:starting zookeeper... already running process 2853
			
今天搭建zookeeper时碰到了starting zookeeper already running process 2853这样一个错误. 上网上查了几个相似的问题都是要删除zookeeper_s ...
 - Docker 安装nginx 与端口映射
			
1. 拉取镜像(网易云docker镜像仓库) docker pull hub.c.163.com/library/nginx:latest 2. 运行nignx,并做端口映射 -d 后台运行 -p映 ...
 - [译] 重新思考 1 号进程 / Rethinking PID 1
			
By Lennart Poettering 译 SReadFox 原文链接:http://0pointer.de/blog/projects/systemd.html 译注:笔者大约在 2011 年读 ...