現在の時間ベース、簡単に取得時間(最後の2日間、先週、最後の2週間、先月、最後の2ヶ月間、過去6ヶ月間、直近の年、週、月、年)JS

別のグラフのデータニーズを取得し、表示するように「一年近く、ほぼ半年、ほぼ月、ほぼ月に、ほぼ一週間」として、異なる期間に応じて遭遇した会社経営のバックグラウンドシステムの開発では、それは、面倒ですプロジェクトの開発サイクルは非常に短く、彼は一瞬考え、アイデアがあるが、それはすぐホイールそれを見つけるためにインターネットは、単にあるので、書くことについての短命の流行は、かなりの時間がかかりますが、幸い、偉大な神は同じことを書かれています効果が、私の実際の需要は少しまだ遠いですから、今のノートを行うには、コードの神への参照を行います。

//格式化时间
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年9月22日」、endTimeは:「2019年9月29日」}、その結果インターフェースの開始日と終了日の唯一の方法、当社の実際のニーズに応じて、必要性は、このようなデータは次のとおりです。

最近一周:[ "2019年9月22日"、 "2019年9月23日"、 "2019年9月24日"、 "2019年9月25日"、 "2019年9月26日"、「2019年9月27日" "2019年9月28日"、 "2019年9月29日"]或者最近一月:[ "2019年8月29日"、 "2019年8月30日"、 "2019年8月31日"、" 2019 -09-01" 、...、 "2019年9月29日"]。

この要件は、ASで作られたX軸を示す同様の線グラフであるので。

それは退屈ではないですか?彼らは、フロントエンド処理、面倒な、舞台裏の同僚はあなたが、とあまりにも多くの問題を扱っていないと言って、フロントエンドインターフェースを書いてみましょう、我々は戻って、この日あなたに来ます。本当に良心ああ!

参考記事:https://www.cnblogs.com/qinacao/p/9117514.html

おすすめ

転載: www.cnblogs.com/tnnyang/p/11607088.html