JS函数 计算 今日,昨日,本周,上周,本月
最近有个功能会进行数据的筛选于是便写了几个快速计算 今日,昨日,本周,上周,本月 范围的function 以便以后遇到同样的问题可以直接进行复用,代码如下:
/*
*获取今日的起始和结束时间
*返回值:"起始时间,结束时间"
*/
function ToDayStr() {
var returnStr = "";
var date = new Date(); //当前时间
var year = date.getFullYear();
var month = date.getMonth() + 1;
var day = date.getDate();
//var hour = date.getHours();
//var minutes = date.getMinutes();
//var second = date.getSeconds();
month = month < 10 ? "0" + month : month;
day = day < 10 ? "0" + day : day;
returnStr = year + "/" + month + "/" + day + " 00:00:00,"; //起始时间
returnStr += year + "/" + month + "/" + day + " 23:59:59"; //结束时间
return returnStr;
} /*
*获取昨日的起始和结束时间
*返回值:"起始时间,结束时间"
*/
function YesterDayStr() {
var date = GetDate(1, 1); //当前时间前一天
var returnStr = "";
var year = date.getFullYear();
var month = date.getMonth() + 1;
var day = date.getDate();
month = month < 10 ? "0" + month : month;
day = day < 10 ? "0" + day : day;
returnStr = year + "/" + month + "/" + day + " 00:00:00,"; //起始时间
returnStr += year + "/" + month + "/" + day + " 23:59:59"; //结束时间
return returnStr;
} /*
*获取本周的起始和结束时间
*返回值:"起始时间,结束时间"
*/
function ThisWeekStr() {
var returnStr = "";
var date = new Date(); //当前时间
var week = date.getDay(); //获取今天星期几
var monday = GetDate2(week - 1, 1, date); //获取星期一
var sunday = GetDate2(7 - week, 2, date); //获取星期天
//起始时间的年月日
var year1 = monday.getFullYear();
var month1 = monday.getMonth() + 1;
var day1 = monday.getDate();
//结束时间的年月日
var year2 = sunday.getFullYear();
var month2 = sunday.getMonth() + 1;
var day2 = sunday.getDate();
//处理起始时间小于10的追加"0"在前面
month1 = month1 < 10 ? "0" + month1 : month1;
day1 = day1 < 10 ? "0" + day1 : day1;
//处理结束时间小于10的追加"0"在前面
month2 = month2 < 10 ? "0" + month2 : month2;
day2 = day2 < 10 ? "0" + day2 : day2; returnStr = year1 + "/" + month1 + "/" + day1 + " 00:00:00,"; //起始时间
returnStr += year2 + "/" + month2 + "/" + day2 + " 23:59:59"; //结束时间
return returnStr;
} /*
*获取上周的起始和结束时间
*返回值:"起始时间,结束时间"
*/
function LastWeekStr() {
var returnStr = "";
var date = new Date(); //当前时间
var week = date.getDay(); //获取今天星期几
var monday = GetDate2(week + 6, 1, date); //获取上周星期一
var sunday = GetDate2(week, 1, date); //获取上周星期天
//起始时间的年月日
var year1 = monday.getFullYear();
var month1 = monday.getMonth() + 1;
var day1 = monday.getDate();
//结束时间的年月日
var year2 = sunday.getFullYear();
var month2 = sunday.getMonth() + 1;
var day2 = sunday.getDate();
//处理起始时间小于10的追加"0"在前面
month1 = month1 < 10 ? "0" + month1 : month1;
day1 = day1 < 10 ? "0" + day1 : day1;
//处理结束时间小于10的追加"0"在前面
month2 = month2 < 10 ? "0" + month2 : month2;
day2 = day2 < 10 ? "0" + day2 : day2; returnStr = year1 + "/" + month1 + "/" + day1 + " 00:00:00,"; //起始时间
returnStr += year2 + "/" + month2 + "/" + day2 + " 23:59:59"; //结束时间
return returnStr;
} /*
*获取本月的起始和结束时间
*返回值:"起始时间,结束时间"
*/
function ThisMonthStr() {
var returnStr = "";
var date = new Date(); //当前时间
var year = date.getFullYear();
var month = date.getMonth(); var min = new Date(year, month, 1); //本月月初
var max = new Date(year, month + 1, 0); //本月月底 //起始时间的年月日
var year1 = min.getFullYear();
var month1 = min.getMonth() + 1;
var day1 = min.getDate();
//结束时间的年月日
var year2 = max.getFullYear();
var month2 = max.getMonth() + 1;
var day2 = max.getDate();
//处理起始时间小于10的追加"0"在前面
month1 = month1 < 10 ? "0" + month1 : month1;
day1 = day1 < 10 ? "0" + day1 : day1;
//处理结束时间小于10的追加"0"在前面
month2 = month2 < 10 ? "0" + month2 : month2;
day2 = day2 < 10 ? "0" + day2 : day2; returnStr = year1 + "/" + month1 + "/" + day1 + " 00:00:00,"; //起始时间
returnStr += year2 + "/" + month2 + "/" + day2 + " 23:59:59"; //结束时间
return returnStr;
} /*
*获取当前日期前N天或后N日期(N = day)
*type:1:前;2:后
*/
function GetDate(day, type) {
var zdate = new Date();
var edate;
if (type === 1) {
edate = new Date(zdate.getTime() - (day * 24 * 60 * 60 * 1000));
} else {
edate = new Date(zdate.getTime() + (day * 24 * 60 * 60 * 1000));
}
return edate;
} /*
*获取传入的日期前N天或后N日期(N = day)
*type:1:前;2:后
*date:传入的日期
*/
function GetDate2(day, type, date) {
var zdate;
if (date === null || date === undefined) {
zdate = new Date();
} else {
zdate = date;
}
var edate;
if (type === 1) {
edate = new Date(zdate.getTime() - (day * 24 * 60 * 60 * 1000));
} else {
edate = new Date(zdate.getTime() + (day * 24 * 60 * 60 * 1000));
}
return edate;
}
这里面需要注意的是不要单纯的在日期或时间上进行加减,注意日期的前后通常处理的都是毫秒数 ,可仿照以上代码中的GetDate 函数思路,仅供参考,如有疑问欢迎大家留言进行交流
JS函数 计算 今日,昨日,本周,上周,本月的更多相关文章
- JS 时间 获取 当天,昨日,本周,上周,本月,上月
调用 setTimeRange (2); function setTimeRange (v) { var fmt = 'YYYY-MM-DD HH:mm'; var now = new Date() ...
- SQL报表语句;SQL获取今日、本周、本月数据
SQL报表语句 SQL获取今日.本周.本月数据 本日:select * from table where datediff(dd,C_CALLTIME,getdate())=0 --C ...
- [moka同学笔记]php 获取时间(今天,昨天,三天内,本周,上周,本月,三年内,半年内,一年内,三年内)
<?php /** * php 获取时间(今天,昨天,三天内,本周,上周,本月,三年内,半年内,一年内,三年内) * * author:ihelloworld2010@gmail.com * d ...
- MySQL查询今天/本周/上周/本月/上个月份的数据
MySQL查询的方式很多,下面为您介绍的MySQL查询实现的是查询本周.上周.本月.上个月份的数据,如果您对MySQL查询方面感兴趣的话,不妨一看. 查询当前今天的数据 SELECT name,sub ...
- 用php获取本周,上周,本月,上月,本季度日期的代码
echo date("Ymd",strtotime("now")), "\n"; echo date("Ymd",str ...
- Asp.net C# 获取本周上周本月上月本年上年第一天最后一天时间大全
DateTime dt = DateTime.Now; int weeknow = Convert.ToInt32(DateTime.Now.DayOfWeek); ) * weeknow + ; D ...
- 今日、本周、本月时间列表 python方法
def get_time(self): ''' @author : Cong @Email : 624420781@qq.com @描 述 : 生产时间列表 ''' # 生成本日时间列表 i = da ...
- PHP获取今日、本周、本月、今年的开始日期和结束日期
/** * 今天开始的Y-m-d H:i:s * * @return string */ public static function beginToday() { return date('Y-m- ...
- mysql查询今日、本周、本月记录
SELECT * FROM table_name WHERE to_days(createtime) = to_days(now()); SELECT * FROM table_name WHERE ...
随机推荐
- SpringSecurity操作指南-在SpringMVC项目上配置Spring Security
- 去掉tableview顶部留白
self.automaticallyAdjustsScrollViewInsets = NO; //去掉tableVIew顶部留白
- ADSL自动更换IP地址源代码
有些网站限制IP地址,什么一个IP地址只能一次之类的.特别是投票网址,为了防止刷票,限制1个IP只允许投票一次! 此程序采用Vs2010+C#开发,提供全部源代码!方便程序猿朋友二次开发! 可以后台运 ...
- (转载)(收藏)OceanBase深度解析
一.OceanBase不需要高可靠服务器和高端存储 OceanBase是关系型数据库,包含内核+OceanBase云平台(OCP).与传统关系型数据库相比,最大的不同点, 是OceanBase是分布式 ...
- .net 调用java rest ful api 实例
注意post的参数组合 HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; request.Method = &quo ...
- Ext.data.SimpleStore的使用方法
Ext.data.SimpleStore简单数据存储器 参数:data:Array数组类型.fields:数组对应的字段名称.var data1=[1,"订单1","16 ...
- WPF 札记
今天在工程中发现了一个非常消耗CPU资源的过程---一个创建Popup并根据绑定的Collection填充ListBox的过程. 通过VS的性能诊断,最终确定的耗时过程锁定在了Popup.isOpen ...
- SQL语句 在一个表中插入新字段
SQL语句 在一个表中插入新字段: alter table 表名 add 字段名 字段类型 例: alter table OpenCourses add Audio varchar(50)alter ...
- Silverlight动态生成控件实例
刚学习Silverlight,做了一个动态创建控件的实例 实现结果:根据已有的控件类名称,得到控件的实例化对象 实现思路1:就是定义一个模板文件,将类名做为参数,在silverlight中使用Srea ...
- windows下使用火狐浏览器插件AutoProxy+MyEnTunnel+SSH访问海外站点(转)
windows下使用火狐浏览器插件AutoProxy+MyEnTunnel+SSH访问海外站点 平时需要查阅一些技术资料,光走VPN太浪费流量,所以这儿教大家一种使用火狐浏览器的插件 AutoPr ...