一些前端javaScript时间处理函数
史上最全时间处理函数(逐行注释)
获取任意周的周一、周末 获取任意月的前后n月的最后一天和第一天
详细函数如下
获取当前周的周一和周末 || 获取当前周的前后n周的周一和周末
函数注释:
入参:
date:基础日期
nWeek:计算的是哪周的周一和周日的日期
date必传 nWeek为数字类型,不传或0代表本周,-1代表上周,1代表下周
1.先将传入的date转换成毫秒数,是因为后续通过毫秒数进行nWeek周的加减
2.将传入的nWeek乘上每周的毫秒数就得到nWeek后的总毫秒数
3.nowTime - (day - 1) 当前传入日期周一的具体毫秒数
4.startTime: 计算得到周一的具体毫秒并加上nWeek
5.endTime: 计算得到周日的具体毫秒并加上nWeek
6.最后通过日期处理函数得到相对应的日期格式并输出数组
入参:
date:基础日期
nWeek:计算的是哪周的周一和周日的日期
date必传 nWeek为数字类型,不传或0代表本周,-1代表上周,1代表下周
getNowTimeWeek(date,nWeek){
let now = new Date(date); // 将不规则日期转换成标准日期格式
let nowTime = now.getTime(); // 将日期转化成毫秒数,以便于加减
let day = now.getDay(); // day为一周(0~6)的某一天的数字[0为周日]
let longTime = 24 * 60 * 60 * 1000; // 一天的毫秒数
let n = longTime * 7 * (nWeek || 0); // nWeek周的毫秒数(可接收负数)
let startTime = nowTime - (day - 1) * longTime + n; // 计算得到周一的具体毫秒并加上nWeek
let endTime = nowTime + (7 - day) * longTime + n; //计算得到周日的具体毫秒并加上nWeek
let solveStartTime = new Date(startTime); // 转换成标准日期格式
let solveEndTime = new Date(endTime); // 同上
let begin = this.toTimeFormat(solveStartTime); // 日期格式处理函数
let finish = this.toTimeFormat(solveEndTime); // 同上
return [begin,finish] // 输出
},
日期格式处理函数
// 日期格式处理函数(自动补零) 输出类型YYYY-MM-DD
toTimeFormat(solveTime){
let y = solveTime.getFullYear();
let m = solveTime.getMonth() + 1;
let d = solveTime.getDate();
m = m < 10 ? "0" + m: m; //补零
d = d < 10 ? "0" + d: d; //补零
let result = y + "-" + m + "-" + d;
return result
},
计算时间间隔
函数注释:
入参:
dateStart: 开始日期
dateEnd: 结束日期
1.将传入的两个日期均转成标准时间格式
2.aDay: 一天的毫秒数
3.通过后者减去前者得到两者时间间隔,间隔除以天数便可以得到间隔的天数,在根据具体需求计算去得时间的取整规则,该函数采取的是向上取整
入参:
dateStart: 开始日期
dateEnd: 结束日期
getTimeDiff(dateStart,dateEnd){
let aDate = new Date(dateStart); // 初始化第一个日期对象,将其转换成标准时间格式
let bDate = new Date(dateEnd); // 同上
let aDay = 24 * 60 * 60 * 1000; // 一天的毫秒时间
let diffDay = Math.ceil( (bDate - aDate) / aDay ); // 计算间隔天数(注意日期隐式转换)
return diffDay
},
补零函数
我们尝试将补零写成函数,减少代码体积
作用:将1-9的数字进行补零操作,其他数字直接输出
入参
m: 数字类型
addZero(m) {
return m < 10 ? "0" + m : m;
},
指定日期的本月最后一天
函数注释:
入参:
time: 指定日期
1.将传入时间转换成标准时间格式
2.获取当前年、当前月
3.new Date技巧,入参第三个可以为负数,当为0的时候就是传入的日期的上一个月的月末(这里理解一下:传入6即是7月份,又传入0 则为六月最后一天)

monthToLastDay(time) {
let date = new Date(time);
let nowMonth = date.getMonth() + 1; //当前月
let nowYear = date.getFullYear(); //当前年
//本月的最后一天
let monthEndDate = new Date(nowYear, nowMonth, 0);
let monthEnd = this.toTimeFormat(monthEndDate);
return monthEnd
},
指定日期的前n个月的第一天
入参
time: 日期
n: 前n个月
getFrontMonthN(time,n) {
let date = new Date(time); //获取标准日期格式
let currentYear = date.getFullYear(); //获取完整的年份
let currentMonth = date.getMonth(); //当前月份(0-11,0代表1月)
let nMonth; //当前月的前两个月
if (currentMonth < n) { // 如果当年月份不足以减去所减n月,则年份减一
currentYear -= 1; //年份减1
nMonth = currentMonth + 12 - n; //当前月的前两个月
} else {
nMonth = currentMonth - n; //当前月的前两个月
}
let nMonthFirstDay = new Date(currentYear, nMonth, 1); //当前月的前三个月的第一天
let monthStart = this.toTimeFormat(nMonthFirstDay );
return monthStart;
},
指定日期的后n个月的最后一天
入参
time: 日期
n: 前n个月
getBackMonthfour(time,n) {
let date = new Date(time); //获取标准日期格式
let currentYear = date.getFullYear(); //获取完整的年份
let currentMonth = date.getMonth() + 1; //当前月份(0-11,0代表1月)
let backNDate = new Date(currentYear, currentMonth + n, 0); //当前月的后四个月的最后一天
let monthEnd = this.toTimeFormat(backNDate);
return monthEnd ;
},
一些前端javaScript时间处理函数的更多相关文章
- JavaScript时间日期函数
//随机数生成器Math.random() 装换为整数parseInt() 日期时间函数(需要用变量调用):var b = new Date(); //获取当前时间b.getTime() //获取时间 ...
- 前端学习 第六弹: javascript中的函数与闭包
前端学习 第六弹: javascript中的函数与闭包 当function里嵌套function时,内部的function可以访问外部function里的变量 function foo(x) { ...
- web前端----JavaScript(JS)函数
函数 函数定义 JavaScript中的函数和Python中的非常类似,只是定义方式有点区别. // 普通函数定义 function f1() { console.log("Hello wo ...
- JavaScript日期时间格式化函数
这篇文章主要介绍了JavaScript日期时间格式化函数分享,需要的朋友可以参考下 这个函数经常用到,分享给大家. 函数代码: //格式化参数说明: //y:年,M:月,d:日,h:时,m分,s:秒, ...
- JavaScript - 时间函数
时间美化函数 /* 1.< 60s, 显示为“刚刚” 2.>= 1min && < 60 min, 显示与当前时间差“XX分钟前” 3.>= 60min &am ...
- 深入理解javascript:揭秘命名函数表达式
这是一篇转自汤姆大叔的文章:http://www.cnblogs.com/TomXu/archive/2011/12/15/2288411.html 前言 网上还没用发现有人对命名函数表达式进去重复深 ...
- python学习之路前端-JavaScript
JavaScript简介 JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本 ...
- Web前端-JavaScript基础教程上
Web前端-JavaScript基础教程 将放入菜单栏中,便于阅读! JavaScript是web前端开发的编程语言,大多数网站都使用到了JavaScript,所以我们要进行学习,JavaScript ...
- 前端——JavaScript
何谓JavaScript?它与Java有什么关系? JavaScript与HTML.CSS组合使用应用于前端开发,JavaScript是一门独立的语言,浏览器内置了JS的解释器.它除了和Java名字长 ...
- Fundebug前端JavaScript插件更新至1.2.0
摘要: Fundebug的前端JavaScript错误监控插件更新至1.2.0:支持监控WebSocket连接错误:修复了监控unhandledrejection错误的BUG,即未用catch处理的P ...
随机推荐
- MYSQL——mysql检索不包含字母U的数据
2024/07/09 1. NOT LIKE 2. IS NOT.<>.!= 3. NOT IN 如题,正确答案如下: SELECT * FROM your_table_name WHER ...
- TwinCAT3 - 实现自己的Dictionary
目录 1,前言 2,C#的字典 3,TwinCAT3的字典 定义功能块 添加方法 4,用起来 1,前言 C#有字典,TwinCAT没字典,咋办,自己写一个咯 2,C#的字典 C#的字典使用很简单,下面 ...
- 【Linux】之切换root用户与重启系统相关命令
一.切换用户 <Linux中怎么从root用户切换到普通用户> su是在用户间切换,可以是从普通用户切换到root用户, test@ubuntu:~$ su Password: root@ ...
- 调用微信红包接口,本地可以服务器不可以。 请求被中止: 未能创建 SSL/TLS 安全通道
微信红包的地址接口地址是: https://api.mch.weixin.qq.com/pay/micropay 当时造成这个不能用的原因是:我把服务器从windows server 2008升级到w ...
- 小tips:HTML的实体
为了能在HTML文档中正确显示某些特殊字符,就需要使用HTML实体(entity).HTML实体就是对当前文档的编码方式不能包含的字符,提供一种转义表示. HTML实体定义 1.名称方式 名称方式会以 ...
- 简单聊聊 CORS 攻击与防御
我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:霁明 什么是CORS CORS(跨域资源共享)是一种基于H ...
- Angular 18+ 高级教程 – Component 组件 の Control Flow
前言 Control Flow 是 Angular v17 版本后推出的新模板语法,用来取代 NgIf.NgForOf.NgSwitch 这 3 个 Structure Directive. Stru ...
- CSS & JS Effect – 画三角形 Triangle
前言 画三角形有什么用? 可以做这样的 Design 参考 5 Ways To Create A Triangle With CSS Border Triangle 用 border 做 三角形应该是 ...
- Python— 函数
函数定义: 示例: # 求 1 - n 的和 def sum(date): sum = 0 for i in range(1,date + 1): sum += i return sum # 函数调用 ...
- Spring —— 核心概念
IoC (Inversion of Control) 控制反转 使用对象时,由主动new产生对象转换为由外部提供对象,对象的创建控制权由程序转移至外部,这种思想成为控制反转 Spring技术对IoC思 ...