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

2024-04-09 15:28

本文主要是介绍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框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)

这篇关于js获取上周本周下周的日期(附Demo)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

通过cmd获取网卡速率的代码

《通过cmd获取网卡速率的代码》今天从群里看到通过bat获取网卡速率两段代码,感觉还不错,学习bat的朋友可以参考一下... 1、本机有线网卡支持的最高速度:%v%@echo off & setlocal enabledelayedexpansionecho 代码开始echo 65001编码获取: >

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息