js获取上周本周下周的日期(附Demo)

目录

  • 前言
  • 1. 基本知识
  • 2. Demo
  • 3. 彩蛋

前言

现在的时间点是:2024-04-08,对应的日期如下(上周、这周、下周)

在这里插入图片描述

1. 基本知识

讲述Demo之前,先补充一些基础知识

JavaScript 中的 Date 对象是用于处理日期和时间的对象。它可以获取当前日期和时间,以及可以对日期和时间进行操作

以下是一些基本的 Date 对象的方法和属性:

var now = new Date(); // 创建一个表示当前时间的 Date 对象
var time = now.getTime(); // 获取当前时间的毫秒数,从 1970 年 1 月 1 日开始计算
var year = now.getFullYear(); // 获取当前年份
var date = now.getDate(); // 获取当前日期
var hour = now.getHours(); // 获取当前小时
var second = now.getSeconds(); // 获取当前秒钟
var week = now.getDay(); // 获取当前星期(注意:返回的是 0 表示星期天,1 表示星期一,以此类推)

其余方法如下:

  • getMilliseconds(): 获取当前毫秒数
  • getUTCFullYear():获取 UTC 时间的年份
  • getUTCMonth():获取 UTC 时间的月份
  • getUTCDate():获取 UTC 时间的日期
  • getUTCHours():获取 UTC 时间的小时
  • getUTCMinutes(): 获取 UTC 时间的分钟
  • getUTCSeconds():获取 UTC 时间的秒钟

注意事项:

  • getMonth() 方法返回的月份是从 0 开始的,所以在实际使用时需要加 1
  • getDay() 返回的是星期几的数字表示,需要使用数组或 switch 语句进行转换

JavaScript 的 Date 对象还提供了一系列设置日期和时间的方法,以及进行日期和时间运算的方法,如 setFullYear()setMonth()setDate()setHours() 等,以及 getTimezoneOffset()toUTCString() 等方法用于处理时区和格式化日期等

2. Demo

  1. 使用 moment.js 库来处理日期操作。
  2. 使用 isoWeekday 获取当前日期是一周的第几天,以确定是在本周还是上周或下周。
  3. 使用 startOf('isoWeek')endOf('isoWeek') 来获取本周的起始日期和结束日期。

根据当前日期的位置,计算上周和下周的日期范围

const moment = require('moment');
// 或者 import moment from 'moment'

calculateWeekPeriods() {
    const today = moment();
    const dayOfWeek = today.isoWeekday();

    // 计算本周的起始日期和结束日期
    const startDateThisWeek = today.clone().startOf('isoWeek');
    const endDateThisWeek = today.clone().endOf('isoWeek');

    // 计算上周和下周的起始日期和结束日期
    const startDateLastWeek = startDateThisWeek.clone().subtract(1, 'week');
    const endDateLastWeek = startDateLastWeek.clone().endOf('isoWeek');
    const startDateNextWeek = startDateThisWeek.clone().add(1, 'week');
    const endDateNextWeek = startDateNextWeek.clone().endOf('isoWeek');

    // 格式化日期范围
    const formatDateRange = (startDate, endDate) => {
        return `${startDate.format('YYYY-MM-DD')}~${endDate.format('YYYY-MM-DD')}`;
    };

    // 生成周期数组
    const weekPeriods = [
        { label: '上周', dateRange: formatDateRange(startDateLastWeek, endDateLastWeek) },
        { label: '这周', dateRange: formatDateRange(startDateThisWeek, endDateThisWeek) },
        { label: '下周', dateRange: formatDateRange(startDateNextWeek, endDateNextWeek) }
    ];

    this.weekPeriods = weekPeriods;
}

通过ES6 中的箭头函数、模板字符串等语法,更加完好的展示如下功能:

// 获取当前日期和时间,包括年、月、日、周几、时、分、秒
const getCurrentDateTime = () => {
    const now = new Date();
    const year = now.getFullYear();
    let month = now.getMonth() + 1;
    let date = now.getDate();
    const day = now.getDay();
    let hour = now.getHours();
    let minu = now.getMinutes();
    let sec = now.getSeconds();

    // 格式化月份、日期、小时、分钟、秒数,保证两位数
    month = month < 10 ? "0" + month : month;
    date = date < 10 ? "0" + date : date;
    hour = hour < 10 ? "0" + hour : hour;
    minu = minu < 10 ? "0" + minu : minu;
    sec = sec < 10 ? "0" + sec : sec;

    // 返回格式化后的字符串
    return `${year}-${month}-${date}${day} 时间: ${hour}:${minu}:${sec}`;
};

// 获取当前日期
const getCurrentDate = () => {
    const startDate = new Date();
    const year = startDate.getFullYear();
    let month = startDate.getMonth() + 1;
    let day = startDate.getDate();

    // 格式化月份、日期,保证两位数
    month = month < 10 ? "0" + month : month;
    day = day < 10 ? "0" + day : day;

    // 返回格式化后的字符串
    return `${year}-${month}-${day}`;
};

// 获取当前日期减去指定天数的日期
const getDateMinusDays = (days) => {
    const nowDate = new Date();
    nowDate.setDate(nowDate.getDate() - days);
    const year = nowDate.getFullYear();
    let month = nowDate.getMonth() + 1;
    let date = nowDate.getDate();

    // 格式化月份、日期,保证两位数
    month = month < 10 ? "0" + month : month;
    date = date < 10 ? "0" + date : date;

    // 返回格式化后的字符串
    return `${year}-${month}-${date}`;
};

// 获取当前日期加上指定天数的日期
const getDatePlusDays = (days) => {
    const nowDate = new Date();
    nowDate.setDate(nowDate.getDate() + days);
    const year = nowDate.getFullYear();
    let month = nowDate.getMonth() + 1;
    let date = nowDate.getDate();

    // 格式化月份、日期,保证两位数
    month = month < 10 ? "0" + month : month;
    date = date < 10 ? "0" + date : date;

    // 返回格式化后的字符串
    return `${year}-${month}-${date}`;
};

// 获取当前日期加减指定天数的日期与具体时间点(时间戳获取)
const getDatePlusMinusDaysWithTime = (days, isPlus = true) => {
    const timestamp = new Date().getTime() / 1000;
    const adjustedTimestamp = isPlus ? timestamp + (60 * 60 * 24 * days) : timestamp - (60 * 60 * 24 * days);
    const adjustedDate = new Date(adjustedTimestamp * 1000);
    const year = adjustedDate.getFullYear();
    let month = adjustedDate.getMonth() + 1;
    let date = adjustedDate.getDate();
    let hour = adjustedDate.getHours();
    let minu = adjustedDate.getMinutes();
    let sec = adjustedDate.getSeconds();

    // 格式化月份、日期、小时、分钟、秒数,保证两位数
    month = month < 10 ? "0" + month : month;
    date = date < 10 ? "0" + date : date;
    hour = hour < 10 ? "0" + hour : hour;
    minu = minu < 10 ? "0" + minu : minu;
    sec = sec < 10 ? "0" + sec : sec;

    // 返回格式化后的日期与时间点
    return `${year}-${month}-${date} ${hour}:${minu}:${sec}`;
};

// 示例:获取当前日期和时间
const currentDateTime = getCurrentDateTime();
console.log("当前日期和时间:", currentDateTime);

// 示例:获取当前日期
const currentDate = getCurrentDate();
console.log("当前日期:", currentDate);

// 示例:获取当前日期减去7天的日期
const dateMinus7Days = getDateMinusDays(7);
console.log("当前日期减去7天的日期:", dateMinus7Days);

// 示例:获取当前日期加上7天的日期
const datePlus7Days = getDatePlusDays(7);
console.log("当前日期加上7天的日期:", datePlus7Days);

// 示例:获取当前日期加减7天的日期与具体时间点(时间戳获取)
const datePlusMinus7DaysWithTime = getDatePlusMinusDaysWithTime(7);
console.log("当前日期加7天的日期与具体时间点:", datePlusMinus7DaysWithTime);

const dateMinusMinus7DaysWithTime = getDatePlusMinusDaysWithTime(7, false);
console.log("当前日期减7天的日期与具体时间点:", dateMinusMinus7DaysWithTime);

3. 彩蛋

此处给出Java后端的写法:

// 获取当前日期
LocalDate currentDate = LocalDate.now();

// 获取本周的起始日期和结束日期
LocalDate startDateThisWeek = currentDate.with(DayOfWeek.MONDAY);
LocalDate endDateThisWeek = currentDate.with(DayOfWeek.SUNDAY);

// 获取上周的起始日期和结束日期
LocalDate startDateLastWeek = startDateThisWeek.minusWeeks(1);
LocalDate endDateLastWeek = endDateThisWeek.minusWeeks(1);

// 获取下周的起始日期和结束日期
LocalDate startDateNextWeek = startDateThisWeek.plusWeeks(1);
LocalDate endDateNextWeek = endDateThisWeek.plusWeeks(1);

对于Java的基本知识推荐阅读:java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/528297.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【ensp】VLAN间通信的解决办法

VLAN间通信简介 VLAN间三层通信是指在VLAN网络中&#xff0c;不同VLAN之间进行通信的过程。 我们知道VLAN是虚拟局域网&#xff0c;在一个局域网内我们是通过Mac地址进行通信&#xff0c;在局域网与局域网之间通过IP地址来通信&#xff0c;大致过程如下&#xff1a; 主机在发…

【SERVERLESS】搭建ServerLess服务

目录 一、前言 二、什么是ServerLess? 三、ServerLess技术选型 四、ServerLess基础服务搭建 Mac安装示例&#xff1a; Windows安装说明&#xff1a; 五、生成ServerLess应用 六、ServerLess部署 验证并访问函数应用 七、ServerLess进阶演示 八、ServerLess最后总结 …

芒果YOLOv8改进组合157:动态标签分配ATSS+新颖高效AsDDet检测头组合改进,共同助力VisDrone涨点1.8%,小目标高效涨点

💡本篇内容:【芒果YOLOv8改进ATSS标签分配策略|第三集】芒果YOLOv8改进组合157:动态标签分配ATSS+新颖高效AsDDet检测头组合改进,共同助力VisDrone涨点1.8%,小目标高效涨点 💡🚀🚀🚀本博客 标签分配策略ATSS改进+ 新颖高效AsDDet检测头组合改进,适用于 YOLOv8 …

免费ai写作软件有哪些?分享10个给你 #媒体#学习#媒体

你是否因为写作困顿而感到沮丧&#xff1f;是不是希望能够找到一个能给你提供无限灵感和提高创作效率的利器&#xff1f;AI写作助手就是你的绝佳选择&#xff01;现在我向大家推荐几款好用的AI写作助手&#xff0c;它们将让你的创作之旅更加流畅、富有创意。 1.飞鸟写作 这是…

超详细解读Transformer框架

Transformer是由谷歌大脑2017年在论文《Attention is All You Need》中提出的一种序列到序列(Seq2Seq)模型。自提出伊始&#xff0c;该模型便在NLP和CV界大杀四方&#xff0c;多次达到SOTA效果。NLP领域中&#xff0c;我们所熟知的BERT和GPT就是从Transformer中衍生出来的预训练…

【云计算】云网络产品体系概述

云网络产品体系概述 在介绍云网络产品体系前&#xff0c;先介绍几个与云计算相关的基础概念。 阿里云在基础设施层面分为 地域 和 可用区 两层&#xff0c;关系如下图所示。在一个地域内有多个可用区&#xff0c;每个地域完全独立&#xff0c;每个可用区完全隔离&#xff0c;同…

咸鱼之王_手游_开服搭建架设_内购修复无bug运营版

视频演示 咸鱼之王_手游_开服 游戏管理后台界面 源码获取在文章末尾 源码获取在文章末尾 源码获取在文章末尾 或者直接下面 https://githubs.xyz/y28.html 1.安装宝塔 yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh &…

Leetcode C语言习题

Leetcode习题27&#xff1a;移除元素 题目&#xff1a; 说明&#xff1a; 示例&#xff1a; 题解&#xff1a; 方法一&#xff1a;&#xff08;开辟额外的数组空间&#xff09; 我们可以创建一个新的数组&#xff0c;然后用循环来遍历原数组&#xff0c;将原数组中不为 val…

29.WEB渗透测试-数据传输与加解密(3)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;28.WEB渗透测试-数据传输与加解密&#xff08;2&#xff09; md5解密网站&#xff1a;ht…

SpringMVC数据接收(全面/详细注释)

SpringMVC涉及组件&#xff1a; DispatcherServlet : SpringMVC提供&#xff0c;我们需要使用web.xml配置使其生效&#xff0c;它是整个流程处理的核心&#xff0c;所有请求都经过它的处理和分发&#xff01;[ CEO ]HandlerMapping : SpringMVC提供&#xff0c;我们需要进行…

高创新 | [24年新算法]NRBO-XGBoost回归+交叉验证基于牛顿拉夫逊优化算法-XGBoost多变量回归预测

高创新 | [24年新算法]NRBO-XGBoost回归交叉验证基于牛顿拉夫逊优化算法-XGBoost多变量回归预测 目录 高创新 | [24年新算法]NRBO-XGBoost回归交叉验证基于牛顿拉夫逊优化算法-XGBoost多变量回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.Matlab实现 [24年新算…

实现 jwt 鉴权- SpringBoot + 微服务

目录 项目结构 主要步骤 auth-service里&#xff1a; 1. 配置 pom.xml 依赖 2. 实现HandlerInterceptor 接口的 preHandle 函数 3. 实现 WebMvcConfigurer 的 addInterceptors 接口 4. 生成 token 和验证 token 5. 登录接口示例 user-service 里&#xff1a; 6. 实现拦…

Netty NioEventLoop详解

文章目录 前言类图主要功能NioEventLoop如何实现事件循环NioEventLoop如何处理多路复用Netty如何管理Channel和Selector管理Channel管理Selector注意事项 前言 Netty通过事件循环机制(EventLoop)处理IO事件和异步任务&#xff0c;简单来说&#xff0c;就是通过一个死循环&…

信息泄露漏洞的JS整改方案

引言 &#x1f6e1;️ 日常工作中&#xff0c;我们经常会面临线上环境被第三方安全厂商扫描出JS信息泄露漏洞的情况&#xff0c;这给我们的系统安全带来了潜在威胁。但幸运的是&#xff0c;对于这类漏洞的整改并不复杂。本文将介绍几种可行的整改方法&#xff0c;以及其中一种…

【C语言】:枚举和联合体

这里写自定义目录标题 1、枚举1.1 枚举类型的声明1.2 枚举类型的优点1.3 枚举类型的使用 2、联合体&#xff08;共用体&#xff09;2.1 联合体类型的声明2.2 联合体的特点2.3联合体大小的计算 1、枚举 1.1 枚举类型的声明 枚举顾名思义就是⼀⼀列举&#xff0c;把可能的取值⼀…

Tomcat以服务方式启动,无法访问网络共享目录问题

关于“Tomcat以服务方式启动&#xff0c;无法访问网络共享目录问题”解决方式如下&#xff1a; 1、通过doc命令【services.msc】打开本地服务找到&#xff0c;找到tomcat服务所在位置 2、右键打开Tomcat服务的属性 3、选择 登陆选项卡 4、选择“此账户”选项&#xff0c;并…

Nginx配置文件修改结合内网穿透实现公网访问多个本地web站点

文章目录 1. 下载windows版Nginx2. 配置Nginx3. 测试局域网访问4. cpolar内网穿透5. 测试公网访问6. 配置固定二级子域名7. 测试访问公网固定二级子域名 1. 下载windows版Nginx 进入官方网站(http://nginx.org/en/download.html)下载windows版的nginx 下载好后解压进入nginx目…

自动驾驶中的多目标跟踪_第二篇

自动驾驶中的多目标跟踪:第二篇 上一节介绍了多目标跟踪的定义、应用场景和类型以及面临的挑战&#xff1b;在这一节&#xff0c;我们回顾贝叶斯滤波&#xff0c;简单介绍运动模型和量测模型&#xff0c;卡尔曼滤波等。 附赠自动驾驶学习资料和量产经验&#xff1a;链接 贝叶…

Spring事务简介,事务角色,事务属性

1.Spring事务简介 事务作用&#xff1a;在数据层保障一系列的数据库操作同成功同失败Spring事务作用&#xff1a;在数据层或业务层保障一系列的数据操作同成功同失败 public interface PlatformTransactionManager{void commit(TransactionStatus status) throws TransactionE…

macU盘在电脑上读不出来 u盘mac读不出来怎么办 macu盘不能写入 Tuxera NTFS for Mac免费下载

对于Mac用户来说&#xff0c;使用U盘是很常见的操作&#xff0c;但有时候可能会遇到Mac电脑无法读取U盘的情况&#xff0c;这时候就需要使用一些特定的工具软件来帮助我们解决问题。本文就来告诉大家macU盘在电脑上读不出来是怎么回事&#xff0c;u盘mac读不出来怎么办。 一、m…