Javascript 日期相关计算
1、获取当前日期的前一天
// 获取当前日期let today = new Date();today.setDate(today.getDate() - 1);// 转换为本地日期字符串格式let yesterdayStr = today.toISOString().slice(0, 10);console.log(yesterdayStr); // 例如: "2023-04-03" (格式取决于地区设置)
2、获取当前日期的上个礼拜的开始时间和结束时间
const today = new Date();
const dayOfWeek = today.getDay(); // 获取今天是周几,0(周日)到6(周六)
const diffDays = today.getDate() - dayOfWeek + (dayOfWeek === 0 ? -6 : 1); // 如果今天是周日,则diffDays为-6,否则为1,用于计算上周一
const monday = new Date(today.setDate(diffDays)); // 上周一的日期
const lastWeekEnd = new Date(monday); // 上周的结束日(周日)lastWeekEnd.setDate(lastWeekEnd.getDate() - 1); // 上上周的结束日(周日的前一天)
const lastWeekStart = new Date(monday); // 上周的结束日(周日)lastWeekStart.setDate(lastWeekStart.getDate() - 7); // 上上周的结束日(周日的前一天)console.log("上上周结束日期:", lastWeekEnd.toISOString().slice(0, 10)); // ISO格式,去掉时间部分
console.log("上上周开始日期:", lastWeekStart.toISOString().slice(0, 10)); // ISO格式,去掉时间部分
3、获取当前日期的上个月的开始时间和结束时间
const today = new Date();let lastMonth = new Date(today);// 设置日期为当前月份的上一个月lastMonth.setMonth(lastMonth.getMonth() - 1);// 设置日期为上个月的第一天(即月初)lastMonth.setDate(1);// 获取上个月的第一天const startOfLastMonth = lastMonth;// 设置日期为下一个月的第一天,从而得到上个月的最后一天const endOfLastMonth = new Date(lastMonth);endOfLastMonth.setMonth(endOfLastMonth.getMonth() + 1);endOfLastMonth.setDate(0); // 这会将日期设置为上个月最后一天// 格式化日期为"YYYY-MM-DD"格式的字符串const startDateStr = startOfLastMonth.toISOString().split("T")[0]; // 或者使用 toLocaleDateString('zh-CN') 并自定义格式化选项const endDateStr = endOfLastMonth.toISOString().split("T")[0]; // 或者使用 toLocaleDateString('zh-CN') 并自定义格式化选项console.log('上个月的开始时间',startDateStr)console.log('上个月的结束时间',endDateStr)
4、JavaScript 中的日期对象
// 创建当前日期和时间的 Date 对象const currentDate = new Date();// 通过指定年、月、日、时、分、秒来创建 Date 对象// 注意:月份是从 0 开始计数的,即 0 表示 1 月,11 表示 12 月const specificDate = new Date(2024, 10, 15, 12, 30, 0);// 通过日期字符串创建 Date 对象const dateFromString = new Date('2024-11-15T12:30:00');Date 对象提供了一系列方法来获取和设置日期与时间的各个部分,例如:const date = new Date();const year = date.getFullYear(); // 获取年份const month = date.getMonth() + 1; // 获取月份(注意要加 1)const day = date.getDate(); // 获取日期const hours = date.getHours(); // 获取小时const minutes = date.getMinutes(); // 获取分钟const seconds = date.getSeconds(); // 获取秒数
5、 计算两个日期之间的天数
计算两个日期之间的天数是一个常见的需求。基本思路是先获取两个日期的时间戳(从 1970 年 1 月 1 日 00:00:00 UTC 到指定日期的毫秒数),然后计算它们的差值,最后将差值转换为天数。function getDaysBetweenDates(startDate, endDate) {const oneDay = 24 * 60 * 60 * 1000; // 一天的毫秒数const firstDate = new Date(startDate).getTime();const secondDate = new Date(endDate).getTime();const diffDays = Math.round(Math.abs((firstDate - secondDate) / oneDay));return diffDays;}const start = '2024-11-01';const end = '2024-11-10';const days = getDaysBetweenDates(start, end);console.log(`两个日期之间相差 ${days} 天。`);
6、计算两个日期之间的月数和年数
计算两个日期之间的月数和年数相对复杂一些,需要考虑月份和年份的变化。function getMonthsBetweenDates(startDate, endDate) {const start = new Date(startDate);const end = new Date(endDate);let months;months = (end.getFullYear() - start.getFullYear()) * 12;months -= start.getMonth();months += end.getMonth();return months <= 0 ? 0 : months;}function getYearsBetweenDates(startDate, endDate) {const start = new Date(startDate);const end = new Date(endDate);return end.getFullYear() - start.getFullYear();}const months = getMonthsBetweenDates(start, end);const years = getYearsBetweenDates(start, end);console.log(`两个日期之间相差 ${months} 个月。`);console.log(`两个日期之间相差 ${years} 年。`);
7、判断某个日期是否在指定区间内
判断某个日期是否在指定的日期区间内,可以通过比较该日期的时间戳与区间两端日期的时间戳来实现。function isDateInRange(date, startDate, endDate) {const target = new Date(date).getTime();const start = new Date(startDate).getTime();const end = new Date(endDate).getTime();return target >= start && target <= end;}const testDate = '2024-11-05';const isInRange = isDateInRange(testDate, start, end);console.log(`${testDate} 是否在 ${start} 到 ${end} 的区间内:${isInRange}`);
8、实际应用案例:酒店预订日期检查
在酒店预订系统中,需要检查用户选择的日期是否在可预订的日期区间内,并且计算预订的天数。<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>酒店预订日期检查</title></head><body><label for="startDate">入住日期:</label><input type="date" id="startDate"><label for="endDate">退房日期:</label><input type="date" id="endDate"><button onclick="checkBooking()">检查预订</button><p id="result"></p><script>function getDaysBetweenDates(startDate, endDate) {const oneDay = 24 * 60 * 60 * 1000;const firstDate = new Date(startDate).getTime();const secondDate = new Date(endDate).getTime();const diffDays = Math.round(Math.abs((firstDate - secondDate) / oneDay));return diffDays;}function isDateInRange(date, startDate, endDate) {const target = new Date(date).getTime();const start = new Date(startDate).getTime();const end = new Date(endDate).getTime();return target >= start && target <= end;}function checkBooking() {const start = document.getElementById('startDate').value;const end = document.getElementById('endDate').value;const availableStart = '2024-11-01';const availableEnd = '2024-11-30';if (isDateInRange(start, availableStart, availableEnd) && isDateInRange(end, availableStart, availableEnd)) {const days = getDaysBetweenDates(start, end);document.getElementById('result').textContent = `预订成功!您预订了 ${days} 天。`;} else {document.getElementById('result').textContent = '抱歉,您选择的日期不在可预订区间内。';}}</script></body></html>
9、注意事项
- 时区问题:JavaScript 的
Date
对象在处理日期和时间时会受到本地时区的影响。如果需要处理跨时区的日期,建议使用Intl.DateTimeFormat
或者第三方库(如moment.js
、day.js
)。 - 日期格式:在使用日期字符串创建
Date
对象时,要确保日期格式符合标准,否则可能会导致Date
对象创建失败。
总结
JavaScript 的 Date
对象为我们提供了处理日期和时间的基本能力,通过合理运用其方法和属性,我们可以实现各种日期区间计算的需求。在实际开发中,根据具体业务场景选择合适的计算方法,并注意处理时区和日期格式等问题。同时,对于复杂的日期处理需求,也可以考虑使用第三方库来简化开发过程。希望本文能帮助你更好地掌握 JavaScript 中的日期区间计算。
整理不易,欢迎大家一键三连哦!😯
相关文章:
Javascript 日期相关计算
1、获取当前日期的前一天 // 获取当前日期let today new Date();today.setDate(today.getDate() - 1);// 转换为本地日期字符串格式let yesterdayStr today.toISOString().slice(0, 10);console.log(yesterdayStr); // 例如: "2023-04-03" (格式取决于地区设置) 2…...
自动驾驶背后的数学:特征提取中的线性变换与非线性激活
在上一篇博客「自动驾驶背后的数学:从传感器数据到控制指令的函数嵌套」—— 揭秘人工智能中的线性函数、ReLU 与复合函数中,我们初步探讨了自动驾驶技术中从传感器数据到控制指令的函数嵌套流程,其中提到了特征提取模块对传感器数据进行线性…...
DNS解析查询工具
dig命令 1 常用命令 命令:dig 您的域名(示例:dig www.baidu.com) 2、根据解析记录查询,比如MX,CNAME,NS,PTR等,只需将类型加在命令后面即可。 示例:dig bai…...
【eNSP实战】(续)一个AC多个VAP的实现—将隧道转发改成直接转发
在 一个AC多个VAP的实现—CAPWAP隧道转发 此篇文章配置的基础上,将隧道转发改成直接转发 一、改成直接转发需要改动的配置 (一)将连接AP的接口改成trunk口,并允许vlan100、101、102通过 [AC1]interface GigabitEthernet 0/0/8 …...
解决远程卡在下载vscode-server的问题,一键安装脚本
vscode-server 下载与安装脚本 vscode-server一键安装脚本 简介 此脚本用于下载并安装指定提交 ID 和架构的 VS Code Server。用户可以选择不同的架构,并输入对应的 VS Code 提交 ID 来下载和安装 vscode-server。VS Code提交ID可以在VS Code界面“帮助>关于…...
【unity实战】用unity封装一个复杂全面且带不同射击模式的飞机大战射击系统
考虑到每个人基础可能不一样,且并不是所有人都有同时做2D、3D开发的需求,所以我把 【零基础入门unity游戏开发】 分为成了C#篇、unity通用篇、unity3D篇、unity2D篇。 【C#篇】:主要讲解C#的基础语法,包括变量、数据类型、运算符、流程控制、面向对象等,适合没有编程基础的…...
LeetCode[42] 接雨水
动态规划 left_max[i] height[i]左侧的最高高度right_max[i] height[i]右侧的最高高度height[i]能接多少水?min(left_max[i], right_max[i])-height[i] class Solution { public:int trap(vector<int>& height) {int len height.size();vector<in…...
c++ 基础题目lambda
1. auto lambda = [](double x) { return static_cast<int>(x); }; 是 匿名函数对象 ,不可直接声明 a.可以赋值给一个与其类型兼容的 std::function 类型的对象 std::function<int(int, int)> lambda = [](int x, int y) { return x + y; }; b.使用具体的 lambda …...
RTSP/Onvif安防视频EasyNVR平台 vs.多协议接入视频汇聚EasyCVR平台:设备分组的区别
EasyNVR安防视频云平台是旭帆科技TSINGSEE青犀旗下支持RTSP/Onvif协议接入的安防监控流媒体视频云平台。平台具备视频实时监控直播、云端录像、云存储、录像检索与回看、告警等视频能力,能对接入的视频流进行处理与多端分发,包括RTSP、RTMP、HTTP-FLV、W…...
网络编程套接字【端口号/TCPUDP/网络字节序/socket编程接口/UDPTCP网络实验】
网络编程套接字 0. 前言1. 认识端口号2. 认识TCP和UDP协议3. 网络字节序4. socket编程接口5. 实现一个简单的UDP网络程序5.1 需求分析5.2 头文件准备5.3 服务器端设计5.4 客户端设计5.5 本地测试5.6 跨网络测试5.7 UDP小应用——客户端输入命令,服务器端执行 6. 地址…...
【C语言预编译处理精选题】
C语言预编译处理精选题 一、选择易错题1.1 纯文本替换,注意优先级!1.2 再来一道文本替换,别马虎1.3 宏定义的替换1.4带参数宏定义的空格问题1.5 " "的include1.6 条件编译1.7 预编译概念 二、填空易错题2.1 注意两个连续的 i2.2 异…...
云钥科技工业相机定制服务,助力企业实现智能智造
在工业自动化、智能制造和机器视觉快速发展的今天,工业相机作为核心感知设备,其性能直接决定了检测精度、生产效率和产品质量。然而,标准化工业相机往往难以满足复杂多样的应用场景需求,工业相机定制逐渐成为企业突破技术瓶颈…...
用了Cline和华为云的大模型,再也回不去了
这两年AI火热,受影响最大的还是程序员群体,因为编程语言是高度形式化的,完全可以用BNF等形式精确地定义,不像自然语言那样,容易出现歧义。另外开源是软件界的潮流,GitHub上有海量的开源代码可供AI来训练&am…...
vs2017版本与arcgis10.1的ArcObject SDK for .NET兼容配置终结解决方案
因电脑用的arcgis10.1,之前安装的vs2010正常能使用AO和AE,安装vs2017后无法使用了,在重新按照新版本arcgis engine或者arcObject费时费力,还需要重新查找资源。 用vs2017与arc10.1的集成主要两个问题,1:安装后vs中没有…...
Java对接微信支付全过程详解
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
微软 System Center Configuration Manager(SCCM)的组件文件
微软 System Center Configuration Manager(SCCM) 或 Microsoft Endpoint Configuration Manager(MECM) 的组件文件,属于企业级设备管理工具的一部分。以下是具体说明: C:\Windows\CCM\smsswd.exe C:\Windows\CCM\tsmanager.exe smsswd.exe 和 tsmanager.exe 是 Micros…...
C语言和C++到底有什么关系?
C 读作“C 加加”,是“C Plus Plus”的简称。 顾名思义,C 就是在 C 语言的基础上增加了新特性,玩出了新花样,所以才说“Plus”,就像 Win11 和 Win10、iPhone 15 和 iPhone 15 Pro 的关系。 C 语言是 1972 年由美国贝…...
10.PE导出表
一:定位导出表 PIMAGE_NT_HEADERS->OptionalHeader->DataDirectory[0] typedef struct _IMAGE_DATA_DIRECTORY {DWORD VirtualAddress; // 导出表的RVADWORD Size; // 导出表大小(没用) } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY; 该结构的Vi…...
springBoot中不添加依赖 , 手动生成一个token ,并校验token,在统一拦截器中进行校验 (使用简单 , 但是安全性会低一点)
要在 Spring Boot 里实现接口统一拦截并校验 Token,可以借助 Spring 的拦截器机制。下面是具体的实现步骤和代码示例。 1. 创建 Token 工具类 import java.nio.charset.StandardCharsets; import java.security.MessageDigest; import java.security.NoSuchAlgori…...
VSCode C/C++ 环境搭建指南
一、前言 Visual Studio Code(简称 VSCode)是一款轻量级且功能强大的跨平台代码编辑器,凭借丰富的插件生态和高度的可定制性,深受开发者喜爱。对于 C/C 开发者而言,在 VSCode 中搭建开发环境,能够获得灵活…...
ES6(4) Map 集合详解
1. Map 集合简介 Map 是 ES6 提供的一种新的键值对数据结构,与普通对象(Object)不同,Map 的键可以是任意类型(包括对象、函数等)。 2. 创建 Map 集合 可以使用 new Map() 创建一个 Map,并在括…...
DeepSeek私有化部署与安装浏览器插件内网穿透远程访问实战
文章目录 前言1. 本地部署OllamaDeepSeek2. Page Assist浏览器插件安装与配置3. 简单使用演示4. 远程调用大模型5. 安装内网穿透6. 配置固定公网地址 前言 最近,国产AI大模型Deepseek成了网红爆款,大家纷纷想体验它的魅力。但随着热度的攀升,…...
【设计模式】建造者模式
三、建造者模式 3.3 建造者模式 建造者(Builder) 模式也称构建器模式、构建者模式或生成器模式,同工厂模式或原型 模式一样,也是一种创建型模式。建造者模式比较复杂,不太常用,但这并不表示不需要了 解和掌握该模式。建造者模式…...
一场由 ES 分片 routing 引发的问题
一场由 ES 分片 routing 引发的问题 ES 结构 {"poroperties": {"joinType": {"type": "join","eager_global_ordinals": true,"relations": {"spu": "sku"}},"id":{"type&q…...
搭建Python量化开发环境:从零开始的完整指南
搭建Python量化开发环境:从零开始的完整指南 在量化投资领域,一个稳定且高效的开发环境是成功的关键。本文将引导你一步步搭建起自己的Python量化开发环境,确保你能够顺利开始编写和运行量化策略。 🚀量化软件开通 Ὠ…...
JavaScript日期区间计算:精准解析年月日差异
一、应用场景与功能概述 在日常的制作项目或者是练习,我们经常需要计算两个日期之间的精确时间差。本文将通过一个JavaScript日期计算函数,详细解析如何实现精准的年/月/日差异计算,并探讨实际开发中的常见问题和解决方案。 二、核心功能解…...
大数据学习(71)-三范式构成
🍋🍋大数据学习🍋🍋 🔥系列专栏: 👑哲学语录: 用力所能及,改变世界。 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言📝支持一…...
el-table 插槽踩过的坑 :slot-scope 和#default的区别
slot-scope和#default是Vue中用于定义插槽的两种不同语法,它们在Vue 2和Vue 3中有不同的应用场景和语法规则。 slot-scope 在Vue 2.x中,slot-scope是用于声明具名插槽并获取父组件传递过来的数据的主要方式。通过slot-scope可以定义一个变量scop…...
Linux一键安装node.js【脚本】
node.js一般不用系统的apt安装,而是用nvm这个前端的应用商店安装 node.js是js环境,nvm是安装nodejs管理器。npm是nodejs里的包管理器,安装模块的,类似于python的pip 把以下代码复制保存在一个文件里 比如nano install_nodejs.sh …...
vue3:pinia安装及其使用
一、安装 Pinia 的步骤 1、安装 Pinia npm install pinia 2、在 Vue 应用中引入 Pinia 在 main.js 中引入并注册 Pinia: import { createApp } from vue; import { createPinia } from pinia; import App from ./App.vue;const app createApp(App); app…...
vue2升级Vue3--native、对inheritAttrs作用做以解释、声明的prop属性和未声明prop的属性
native取消 在 Vue 3 中,v-on 的 .native 修饰符已经被移除。在 Vue 2 中,.native 修饰符用于在组件的根元素上监听原生 DOM 事件,但在 Vue 3 中,这一行为发生了变化。 在 Vue 3 中,所有未在子组件的 emits 选项中定…...
【漫话机器学习系列】146.Softmax 激活函数(Softmax Activation Function)
Softmax 激活函数详解 1. Softmax 函数概述 Softmax 函数(Softmax Activation Function)是一种常用于多分类任务的激活函数,广泛应用于机器学习和深度学习模型,特别是在神经网络的输出层。它的主要作用是将输入的多个实数值转换…...
解决:ModuleNotFoundError: No module named ‘_sqlite3‘
报错: from _sqlite3 import * ModuleNotFoundError: No module named _sqlite3安装sqlite3支持组件: sudo apt-get install libsqlite3-dev进入之前下载的python包下,重新编译和安装Python ./configure --enable-loadable-sqlite-extensions make &a…...
C++差分风暴:区间修改终极模板
目录 🔥 差分核心价值 🌟 一维差分模板 1. 核心思想 2. 代码实现 3. 动态图示 📦 二维差分模板 1. 核心公式 2. 代码实现 3. 二维修改示意图 🚨 六大避坑指南 💡 复杂度对比 🌈 LeetCode实战 &…...
easypoi导入Excel兼容日期和字符串格式的日期和时间
问题场景 在使用easypoi导入Excel时,涉及到的常用日期会有yyyy-MM-dd HH:mm:ss、yyyy-MM-dd和HH:mm:ss,但是Excel上面的格式可不止这些,用户总会输入一些其他格式,如 如果在定义verify时用下面这种格式定义,那么总会…...
《保险科技》
自己在保险行业工作很多年,只是接触了一些数据的内容,对于保险业务的知识了解的很少,想通过这本书补充一下,但是发现这本书就是一些知识的拼接。 先将保险的历史,后讲保险的定义,然后就是吹嘘保险行业和互联…...
QT编程之HTTP服务端与客户端技术
一、HTTP 服务器实现方案 QtWebApp 集成 将QtWebApp源码的 httpserver 目录导入项目,并在 .pro 文件中添加 include ($$PWD/httpserver/httpserver.pri)。配置 WebApp.ini 文件定义服务参数(IP、端口、线程池等),通过 HttpL…...
每日一题--计算机网络
一、基础概念类问题 1. TCP 和 UDP 的区别是什么? 回答示例: TCP:面向连接、可靠传输(通过三次握手建立连接,丢包重传)、保证数据顺序(如文件传输、网页访问)。 UDP:无…...
IIS 服务器日志和性能监控
Internet Information Services (IIS) 是 Microsoft 提供的一款功能强大、灵活且可扩展的 Web 服务器,用于托管网站、服务和应用程序。IIS 支持 HTTP、HTTPS、FTP、SMTP 和更多用于提供网页的协议,因此广泛用于企业环境。 IIS 的…...
Unity学习之Shader总结(一)
一、Lesson1 1、渲染流水线 (1)应用阶段 模型->模型处理(应用阶段)–>输入结构 应用阶段主要操作:粗粒度剔除、进行渲染设置、准备基本数据、输出到几何阶段 (2)几何阶段 输入结构-&…...
java,poi,提取ppt文件中的文字内容
注意,不涉及图片处理。 先上pom依赖: <!-- 处理PPTX文件 --><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>5.2.3</version></dependency><!--…...
matlab R2024b下载教程及安装教程(附安装包)
文章目录 前言一、matlab R2024b 安装包下载二、matlab R2024b安装教程 前言 为帮助大家顺利安装该版本软件,特准备matlab R2024b下载教程及安装教程,它将以简洁明了的步骤,指导你轻松完成安装,开启 MATLAB R2024 的强大功能之旅…...
设计模式之外观模式:原理、实现与应用
引言 外观模式(Facade Pattern)是一种结构型设计模式,它通过提供一个统一的接口来简化复杂系统的使用。外观模式隐藏了系统的复杂性,使得客户端可以通过一个简单的接口与系统交互。本文将深入探讨外观模式的原理、实现方式以及实…...
移远QuecPython模组中的看门狗技术:如何提升设备可靠性
概述 对蜂窝通信模组而言,看门狗(Watchdog)是一种硬件或软件的监控机制,用于监测模组的运行状态。当模组因为外界干扰或程序错误陷入死循环时,看门狗会自动触发模组重启,从而恢复模组的运行状态。 对看门…...
汽车感性负载-智能高边钳位能量计算
随着汽车电子技术的发展,新的电子电气架构下,越来越多的执行部件在车身出现,比如电磁阀、风机、水泵、油泵、雨刮继电器等常用的执行器, 它们一般都表现为感性特点。驱动这些负载的最简单和最常见的方法是将它们连接到高边侧开关(…...
Kubernetes之ETCD
ETCD 是 Kubernetes 的核心组件之一,它是一个分布式键值对存储数据库,专为高可用性和一致性设计。它在 Kubernetes 中的主要作用是存储所有集群数据,包括配置数据和状态信息。ETCD 是 Kubernetes 的“大脑”,其稳定性对整个集群至…...
通过Geopandas进行地理空间数据可视化
目录 引言 安装与导入 数据加载与探索 数据预处理 基本地图可视化 添加其他数据到地图上 空间分析与查询 地图叠加与分组 空间缓冲区 交互式地图可视化 实际应用案例 城市规划 环境监测 结论 引言 在数据科学领域,地理空间数据可视化扮演着至关重要的角色。它不…...
堆(heap)
堆?对于初学者来说,或许是一个陌生十足的概念。 但!堆不可怕。 什么是堆? 学术上,常常是这样说的(一个完全二叉树)。 没毛病,要想更好的理解堆(heap),确实需要好好掌…...
Leetcode-回溯-组合型
22. 括号生成 - 力扣(LeetCode) 这题并没有才有恢复现场的做法 而是直接覆盖 题目核心是看穿本质 在代码执行过程中左括号必须大于等于右括号 以及回溯最底层的递归条件是递归长度已经达到2n 还有做括号要小于n 又因为i左右 因此右等于i-左 ope…...
Modbus通信协议基础知识总结
1. 数据类型与存储区分类 Modbus协议将数据分为四类存储区,通过存储区代号区分: 输出线圈(0x):可读写,对应二进制开关量(如继电器状态),地址范围000001-065536ÿ…...