XingYun blog
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具

XingYun

冲!
  • JS基础

    • 图解js原型链
    • JS Event Loop
    • 对象的底层数据结构
    • 让你的JavaScript代码简单又高效
    • 函数参数按值传递
    • 判断数据类型
    • 浮点数精度问题和解决办法
    • 常用方法snippet
    • 实现Promise
    • 防抖和节流
    • 巧用sort排序
  • CSS && HTML

    • CSS也需要性能优化
    • class命名规范
    • em、px、rem、vh、vw 区别
    • CSS揭秘阅读笔记
  • 浏览器

    • 浏览器是如何渲染页面的
    • 重排和重绘
    • BOM浏览器对象模型
    • DOM事件
    • 浏览器存储
  • 数据结构

    • JS实现链表
    • JS实现栈与栈应用
    • JS实现常见排序
    • 哈夫曼编码
    • MD5算法
  • vue原理浅析

    • Vue虚拟dom与Diff算法
    • 前端打包文件的缓存机制
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
  • 前端工程化

    • 浏览器是如何渲染页面的
    • 前端打包需要gzip压缩吗
    • 前端打包文件的缓存机制
    • webpack loader和plugin
  • 轮子&&组件库

    • 实现水波浪进度球
  • 文字转语音mp3文件
  • 文件上传前后端实现
  • moment.js给定时间获取自然月、周的时间轴
  • 实现文件上传功能
  • 批量下载照片
  • leaflet改变坐标原点
  • 网络

    • 有了MAC地址 为什么还需要IP地址
    • 为什么IP地址老是变
    • 我们为什么需要IPV6
    • TCP与UDP
  • 计算机组成原理

    • ASCII、Unicode、UTF-8和UTF-16
  • VSCode

    • VSCode图片预览插件 Image preview
    • rsync:linux间的高效传输工具
  • 3个提升Vue性能的写法
  • 重读Vue文档
  • moment.js给定时间获取自然月、周的时间轴
    • Vue虚拟dom与Diff算法
    • 深入响应式原理
    • Echart样例
    • 我的Vue指令库
    • 滚动到底部加载更多
    • 实现一键换肤
    • 手写Vue数据劫持
    • vue-router核心原理与手写实现
    • computed和watch
    • vue数组为什么不是响应式
    • v-for为什么不能用index做key
    • webpack loader和plugin
    • keep-alive组件原理
    • vue插槽进化
    • Vue多层嵌套组件
    • vue生命周期hook
    • vue监听dom元素的resize事件
    • 前端打包需要gzip压缩吗
    • 实现水波浪进度球
    • Vue
    XingYun
    2021-11-12
    目录

    moment.js给定时间获取自然月、周的时间轴

    # 1.需求

    请添加图片描述
    要实现这个时间轴的自然周、自然月的选择功能,需要思考两个问题

    1. 处理给定时间的本周与本月时间的显示,如输入 2021-07-29,最后一个月就是 2021-07-01 -
      2021-07-29,最后一周就是 2021-07-26 - 2021-07-29
    2. 获取往前的自然月和周的第一天和最后一天(每周固定七天好处理,每月的天数不确定,需要特殊处理)

    # 2.给定时间 获取自然月、周的时间范围

    处理周参数思路

    moment().weekday(0) 设置日期为当前时区周一
    moment().weekday(6) 设置日期为当前时区周日

    处理月参数思路
    当前月的最后一天的时间戳等于上个月的最后一天 + 24 _ 3600
    const day1Unix = moment().date(1)).unix() // 获取当月 1 号日期时间戳
    const dayLast = moment.unix(day1Unix - 24 _ 3600) // 获得上个月最后一天日期

    根据上面的思路

    # 3.获取时间轴 list

    // 导入moment 并设置时间区域为中国
    import moment from 'moment'
    moment.locale('zh-cn')
    /**
     * 根据时间刻度 day week month 生成对应的时间段列表
     * step: 时间段刻度 day | week | month
     * num: 输出多少组数据
     * displayTimeFormat: 显示时间的格式(可自定义)
     * rangeTimeFormat: 时间范围的格式(可自定义)
     */
    export const getRangeTimeList = function(
      step,
      num = 50,
      displayTimeFormat = 'YYYY年MM月DD日',
      rangeTimeFormat = 'YYYY-MM-DD'
    ) {
      let now = moment() // 当前日期
      let result: any[] = []
      const oneDayTime = 24 * 3600 // 一天的秒数 注意不是毫秒数
      let currentUnix = now.unix() // 当前unix时间戳
    
      const getTimeRange = (begin, end) => {
        return [begin.format(rangeTimeFormat), end.format(rangeTimeFormat)]
      }
      const getDisplayTime = (begin, end) => {
        return begin.format(displayTimeFormat) + '-' + end.format(displayTimeFormat)
      }
    
      if (step === 'day') {
        for (let k = 1; k <= num; k++) {
          const obj: any = {}
          const day = moment.unix(currentUnix)
          obj.timeRange = getTimeRange(day, day)
          obj.tooltip = getDisplayTime(day, day)
          result.push(obj)
          currentUnix -= oneDayTime
        }
      }
      if (step === 'week') {
        // 处理当前这周
        const lastWeek: any = {}
        const firstDay = moment(now).weekday(0)
        lastWeek.timeRange = getTimeRange(firstDay, now)
        lastWeek.tooltip = getDisplayTime(firstDay, now)
        currentUnix = firstDay.unix()
        result.push(lastWeek)
        // 处理剩余n-1周
        for (let k = 2; k <= num; k++) {
          const obj: any = {}
          const sunday = moment.unix(currentUnix - oneDayTime) // 当前周-时间戳减去一天 等于上周日时间戳
          const monday = moment(moment.unix(currentUnix - oneDayTime).weekday(0))
          obj.timeRange = getTimeRange(monday, sunday)
          obj.tooltip = getDisplayTime(monday, sunday)
          result.push(obj)
          currentUnix -= oneDayTime * 7
        }
      }
      if (step === 'month') {
        // 处理当前月
        const lastMonth: any = {}
        const firstDate = moment(now).date(1)
        lastMonth.timeRange = getTimeRange(firstDate, now)
        lastMonth.tooltip = getDisplayTime(firstDate, now)
        currentUnix = firstDate.unix()
        result.push(lastMonth)
        // 处理剩余n-1个月
        for (let k = 2; k <= num; k++) {
          const obj: any = {}
          const dayLast = moment.unix(currentUnix - oneDayTime) // 当前月第一天时间戳减去一天 等于上个月最后一天时间戳
          const n = dayLast.date()
          const day1 = moment(moment.unix(currentUnix - oneDayTime).date(1))
          obj.timeRange = getTimeRange(day1, dayLast)
          obj.tooltip = getDisplayTime(day1, dayLast)
          result.push(obj)
          currentUnix -= oneDayTime * n
        }
      }
      return result
    }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79

    测试一下

    const day = getRangeTimeList('day')
    const week = getRangeTimeList('week')
    const month = getRangeTimeList('month')
    console.log('🚀 ~ day', day)
    console.log('🚀 ~ week', week)
    console.log('🚀 ~ month', month)
    
    1
    2
    3
    4
    5
    6

    得到
    day

    week

    month

    上次更新: 2023/04/05, 09:41:10
    重读Vue文档
    Vue虚拟dom与Diff算法

    ← 重读Vue文档 Vue虚拟dom与Diff算法→

    最近更新
    01
    JavaScript-test
    07-20
    02
    二维码的原理
    07-20
    03
    利用ChatGPT优化代码
    07-20
    更多文章>
    Theme by Vdoing | Copyright © 2021-2023 XingYun | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式