項目統(tǒng)計中遇到:mysql 獲取 當(dāng)年年周次证薇。到前端來用js轉(zhuǎn)換成日期區(qū)間
function getXDate(year,weeks){
????????var date = newDate(year,"0","1");
????????var time = date.getTime();
????????// 獲取當(dāng)前星期幾,0:星期一 。。族购。躬贡。
????????var _week = date.getDay();
????????//當(dāng)這一年的1月1日為周日時則本年有54周,否則沒有54周见坑,沒有則去除第54周的提示
????????if(_week!=0){//一年53周情況
????????????????????if(weeks==54){
????????????????????????return'今年沒有54周';
????????????????????}
????????????????????var cnt=0;// 獲取距離周末的天數(shù)
????????????????????if(_week==0){
????????????????????????cnt = 7;
????????????????????}elseif(_week==1){
????????????????????????cnt = 6;
????????????????????}elseif(_week==2){
????????????????????????cnt = 5;
????????????????????}elseif(_week==3){
????????????????????????cnt = 4;
????????????????????}elseif(_week==4){
????????????????????????cnt = 3;
????????????????????}elseif(_week==5){
????????????????????????cnt = 2;
????????????????????}elseif(_week==6){
????????????????????????cnt = 1;
????????????????????}
????????????????????cnt += 1;//加1表示以星期一為一周的第一天
????????????????????// 將這個長整形時間加上第N周的時間偏移
????????????????????time += cnt*24*3600000; //第2周開始時間
????????????????????var nextYear = newDate(parseInt(year,10)+1,"0","1");
????????????????????var nextWeek = nextYear.getDay();
????????????????????var lastcnt = 0;//獲取最后一周開始時間到周末的天數(shù)
????????????????????if(nextWeek==0){
????????????????????????lastcnt = 6;
????????????????????}elseif(nextWeek==1){
????????????????????????lastcnt = 0;
????????????????????}elseif(nextWeek==2){
????????????????????????lastcnt = 1;
????????????????????}elseif(nextWeek==3){
????????????????????????lastcnt = 2;
????????????????????}elseif(nextWeek==4){
????????????????????????lastcnt = 3;
????????????????????}elseif(nextWeek==5){
????????????????????????lastcnt = 4;
????????????????????}elseif(nextWeek==6){
????????????????????????lastcnt = 5;
????????????????????}
????????????????????if(weeks==1){//第1周特殊處理
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????var start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(time-24*3600000);
????????????????????????returnstart +'--'+ date.format("yyyy年MM月dd日");
????????????????????}elseif(weeks==53){//第53周特殊處理
????????????????????????var start = time+(weeks-2)*7*24*3600000; //第53周開始時間
????????????????????????var end = time+(weeks-2)*7*24*3600000+ lastcnt*24*3600000- 24*3600000; //第53周結(jié)束時間
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????date.setTime(start);
????????????????????????var _start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(end);
????????????????????????var _end = date.format("yyyy年MM月dd日");
????????????????????????return_start +'--'+ _end;
????????????????????}else{
????????????????????????var start = time+(weeks-2)*7*24*3600000; //第n周開始時間
????????????????????????var end = time+(weeks-1)*7*24*3600000- 24*3600000; //第n周結(jié)束時間
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????date.setTime(start);
????????????????????????var _start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(end);
????????????????????????var _end = date.format("yyyy年MM月dd日");
????????????????????????return_start +'--'+ _end;
????????????????????}
????????}else{//一年54周情況
????????????????????var cnt=0;// 獲取距離周末的天數(shù)
????????????????????if(_week==0&& weeks==1){//第一周
????????????????????????cnt = 0;
????????????????????}elseif(_week==0){
????????????????????????cnt = 7;
????????????????????}elseif(_week==1){
????????????????????????cnt = 6;
????????????????????}elseif(_week==2){
????????????????????????cnt = 5;
????????????????????}elseif(_week==3){
????????????????????????cnt = 4;
????????????????????}elseif(_week==4){
????????????????????????cnt = 3;
????????????????????}elseif(_week==5){
????????????????????????cnt = 2;
????????????????????}elseif(_week==6){
????????????????????????cnt = 1;
????????????????????}
????????????????????cnt += 1;//加1表示以星期一為一周的第一天
????????????????????// 將這個長整形時間加上第N周的時間偏移
????????????????????time += 24*3600000; //第2周開始時間
????????????????????var nextYear = newDate(parseInt(year,10)+1,"0","1");
????????????????????var nextWeek = nextYear.getDay();
????????????????????var lastcnt = 0;//獲取最后一周開始時間到周末的天數(shù)
????????????????????if(nextWeek==0){
????????????????????????lastcnt = 6;
????????????????????}elseif(nextWeek==1){
????????????????????????lastcnt = 0;
????????????????????}elseif(nextWeek==2){
????????????????????????lastcnt = 1;
????????????????????}elseif(nextWeek==3){
????????????????????????lastcnt = 2;
????????????????????}elseif(nextWeek==4){
????????????????????????lastcnt = 3;
????????????????????}elseif(nextWeek==5){
????????????????????????lastcnt = 4;
????????????????????}elseif(nextWeek==6){
????????????????????????lastcnt = 5;
????????????????????}
????????????????????if(weeks==1){//第1周特殊處理
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????var start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(time-24*3600000);
????????????????????????returnstart +'--'+ date.format("yyyy年MM月dd日");
????????????????????}elseif(weeks==54){//第54周特殊處理
????????????????????????var start = time+(weeks-2)*7*24*3600000; //第54周開始時間
????????????????????????var end = time+(weeks-2)*7*24*3600000+ lastcnt*24*3600000- 24*3600000; //第53周結(jié)束時間
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????date.setTime(start);
????????????????????????var _start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(end);
????????????????????????var _end = date.format("yyyy年MM月dd日");
????????????????????????return_start +'--'+ _end;
????????????????????}else{
????????????????????????var start = time+(weeks-2)*7*24*3600000; //第n周開始時間
????????????????????????var end = time+(weeks-1)*7*24*3600000- 24*3600000; //第n周結(jié)束時間
????????????????????????// 為日期對象 date 重新設(shè)置成時間 time
????????????????????????date.setTime(start);
????????????????????????var _start = date.format("yyyy年MM月dd日");
????????????????????????date.setTime(end);
????????????????????????var _end = date.format("yyyy年MM月dd日");
????????????????????????return_start +'--'+ _end;
????????????????????}
????????}
}
附:dataformat:
Date.prototype.format = function (fmt) {
? ? var o = {
? ? ? ? "M+": this.getMonth() + 1, //月份
? ? ? ? "d+": this.getDate(), //日
? ? ? ? "h+": this.getHours(), //小時
? ? ? ? "m+": this.getMinutes(), //分
? ? ? ? "s+": this.getSeconds(), //秒
? ? ? ? "q+": Math.floor((this.getMonth() + 3) / 3), //季度
? ? ? ? "S": this.getMilliseconds() //毫秒
? ? };
? ? if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
? ? for (var k in o)
? ? if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
? ? return fmt;
}