在vue项目中使用momentjs获取今日、昨日、本周、本月、上月、本年、上年等日期,时间比较计算
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
使用了momentjs之后发现这个日期处理控件实在是太强大了,参考下面的代码了解详细用法:
日期格式化
官网给出的几种情况(都是当前日期,若指定日期date, moment(date).format())
# 精确到毫秒
moment().valueOf()
## 1584182611042 ;返回值为数值类型
moment().format('x')
## 返回值为字符串类型
# 精确到秒
moment().unix()
## 1584182618 精确到秒 返回值为数值类型
moment().fomoment().format('X')
## 返回值为字符串类型
生成指定时间的moment
moment().format('MMMM Do YYYY, h:mm:ss a'); // 三月 18日 2020, 9:31:24 上午
moment().format('dddd'); // 星期三
moment().format("MMM Do YY"); // 3月 18日 20
moment().format('YYYY [escaped] YYYY'); // 2020 escaped 2020
moment().format(); // 2020-03-18T09:31:24+08:00
## 根据固定的值转化为时分秒
let time = this.$moment.duration(val, 'seconds') //得到一个对象,里面有对应的时分秒等时间对象值
let hours = time.hours()
let minutes = time.minutes()
let seconds = time.seconds()
item.valueC = this.$moment({h:hours, m:minutes, s:seconds}).format('HH:mm:ss')
获取对象
moment().toObject();
# 返回一个包括:年、月、日、时、分、秒、毫秒的对象
# {
years: 2020
months: 2
date: 14
hours: 18
minutes: 47
seconds: 56
milliseconds: 526
}
格式化:
moment().format();
# 2020-03-14T19:14:05+08:00
获取时间:
# 获取今天0时0分0秒
moment().startOf('day')
# 获取本周第一天(周日)0时0分0秒
moment().startOf('week')
# 获取本周周一0时0分0秒
moment().startOf('isoWeek')
# 获取当前月第一天0时0分0秒
moment().startOf('month')
# 获取指定日期的0时0分0秒
moment('2019-10-20').startOf('day')
# 获取今天23时59分59秒
moment().endOf('day')
# 获取本周最后一天(周六)23时59分59秒
moment().endOf('week')
# 获取本周周日23时59分59秒
moment().endOf('isoWeek')
# 获取当前月最后一天23时59分59秒
moment().endOf('month')
获取当月第一天是星期几:
# 用于设置星期几,其中星期日为 0、星期六为 6
moment().startOf('month').day()
获取前n天 / 后n天
moment().add(7, 'days');
moment().subtract(7, 'days')
比较两个时间的大小:
# 第二个参数用于确定精度,且不仅仅是要检查的单个值,因此使用 day 将会检查年份、月份、日期。
moment('2010-10-31').isBefore('2010-12-31', 'day');
# true
moment('2010-10-20').isBefore('2010-12-31', 'year');
# false
moment('2010-10-20').isAfter('2009-12-31', 'year');
# true
moment('2010-10-20').isSame('2009-12-31', 'year');
# 判断两个时间是否相等
# 需要注意的是, isBefore与isAfter 都是开区间,如果想使用闭区间,应使用
isSameOrBefore
isSameOrAfter
两个时间的相差几天:
moment([2008, 2, 27]).diff([2007, 0, 28], 'day');
# 424
是否是闰年:
moment().isLeapYear();
# true
moment([2001]).isLeapYear()
# false
获取 月份和星期 枚举列表:
moment.months()
# ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
moment.monthsShort()
# ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
moment.weekdays()
# ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]
moment.weekdaysMin()
# ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"]
moment().format('YYYY-MM-DD HH:mm:ss');
# 2020-03-14 19:23:29
moment(date).format('YYYY-MM-DD HH:mm:ss')
moment(date).format('YYYY-MM-DD')
moment(date).format('YYYY~MM~DD HH:mm:ss')
moment(date).format('YYYY~MM~DD')
// 由此类推还可以自定义很多种格式,包括这种混合分隔符号也是可以的,当然现实中很少有这样的需求
moment(date).format('YYYY~MM~DD HH+mm:ss')
项目中日期快捷选择:今日、昨日、本周、 上周、 本月、 上月、 本年、 去年
//假设今天为2020.12.2号
//本月第一天
moment().startOf('month').format('YYYY-MM-DD'); //2020-12-01
//本月最后一天
moment().endOf('month').format('YYYY-MM-DD'); //2020-12-31
//上个月第一天
moment().subtract(1,'month').startOf('month').format('YYYY-MM-DD') //2020-11-01
//上月最后一天
moment().subtract(1,'month').endOf('month').format('YYYY-MM-DD') //2020-11-30
//今年第一天
moment().startOf('year').format('YYYY-MM-DD') //2020-01-01
//去年第一天
moment().subtract(1,'year').startOf('year').format('YYYY-MM-DD') //2019-01-01
//去年最后一天
moment().subtract(1,'year').endOf('year').format('YYYY-MM-DD') //2019-12-31
//一年前
moment().subtract(1,'year').format('YYYY-MM-DD'); //2019-12-02
//昨天
moment().subtract(1,'day').format('YYYY-MM-DD') //2020-12-01
//今天
moment().format('YYYY-MM-DD') //2020-12-02
// 本季度
const start = moment().startOf('quarter').format('YYYY-MM-DD') // 开始
const end = moment().endOf('quarter').format('YYYY-MM-DD') // 结束
// 上季度
const start = moment().quarter(moment().quarter() - 1).startOf('quarter').format('YYYY-MM-DD')
const end = moment().quarter(moment().quarter() - 1).endOf('quarter').format('YYYY-MM-DD')
// 本周
const start = moment().startOf('week') .add(1, 'day').format('YYYY-MM-DD HH:mm:ss')
const end = moment().endOf('week').add(1, 'day').format('YYYY-MM-DD HH:mm:ss')
// 上周
const start = moment().subtract(weekOfDay + 7 - 1, 'days') .format('YYYY-MM-DD')
const end = moment().subtract(weekOfDay, 'days') .format('YYYY-MM-DD')
// 本年
const start = moment() .year(moment().year()) .startOf('year') .format('YYYY-MM-DD')
const end = moment() .year(moment().year()) .endOf('year').format('YYYY-MM-DD')
3、时间比较
// 获取当前时间
moment() // 获取当前时间
moment().diff(moment('2020-07-08'),'days') // 当前时间和指定时间对比
// 两个自定义的时间对比
moment('2020-08-09').diff(moment('2020-07-08'),'days') //32
let diff = moment(date1).format('x') - moment(date1).format('x');
let time = moment.duration(diff);
let days = time.days();//天数差
let hours = time.hours();//小时差
let minutes = time.minutes();//分钟差
时间加减法,根据当前日期(date)和给定差值(num),和要计算的类型(type,可以是years,months,weeks,days,hours,minutes,seconds)推算前多少个日期,如下:
moment(date).subtract(num, type).format('YYYY-MM-DD HH:mm:ss');
//推算(2020-03-25 00:00:00)前一年
moment("2020-03-25 00:00:00").subtract(1, "years").format('YYYY-MM-DD HH:mm:ss');//2019-03-25 00:00:00
//推算(2020-03-25 00:00:00)前5天
moment("2020-03-25 00:00:00").subtract(5, "days").format('YYYY-MM-DD HH:mm:ss');//2020-03-20 00:00:00
moment(date).add(num, type).format('YYYY-MM-DD HH:mm:ss');
//推算(2020-03-25 00:00:00)后一年
moment("2020-03-25 00:00:00").add(1, "years").format('YYYY-MM-DD HH:mm:ss');//2021-03-25 00:00:00
//推算(2020-03-25 00:00:00)后5天
moment("2020-03-25 00:00:00").add(5, "days").format('YYYY-MM-DD HH:mm:ss');//2020-03-30 00:00:00
js通过Moment.js让数值秒值和时分秒格式相互转化
/ / 1、把时分秒格式转化为数值型的秒值
<script src="https://momentjs.com/downloads/moment.js"></script>
<script>
let time=moment.duration('01:01:01').as('seconds')
console.log(time) //3661
</script>
// 2、把数值型的秒值转化为时分秒格式
<script src="https://momentjs.com/downloads/moment.js"></script>
<script>
let time = moment.duration(3661, 'seconds') //得到一个对象,里面有对应的时分秒等时间对象值
let hours = time.hours()
let minutes = time.minutes()
let seconds = time.seconds()
console.log(moment({h:hours, m:minutes, s:seconds}).format('HH:mm:ss'))
//01:01:01
</script>
iso8601时间处理:
let t_1 = this.$moment().format('YYYY-MM-DD') + " 08:30:00"
let t_2 = this.$moment().format('YYYY-MM-DD') + " 20:30:00"
let t1 = this.$moment(t_1,'YYYY-MM-DD HH:mm:ss').valueOf()
let t2 = this.$moment(t_2,'YYYY-MM-DD HH:mm:ss').valueOf()
let t = this.$moment().valueOf()
let timeInterval = []
if (t < t1) {
let p_t = this.$moment().format('YYYY-MM-DD') + "T08:30:00.000Z"
let s_t = this.$moment().subtract(1,'d').format('YYYY-MM-DD') + "T20:30:00.000Z"
timeInterval = [s_t, p_t]
} else if (t1 < t < t2) {
let p_t = this.$moment().format('YYYY-MM-DD') + "T08:30:00.000Z"
let s_t = this.$moment().format('YYYY-MM-DD') + "T20:30:00.000Z"
timeInterval = [p_t, s_t]
} else if (t > t1) {
let p_t = this.$moment().format('YYYY-MM-DD') + "T08:30:00.000Z"
let s_t = this.$moment().add(1,'d').format('YYYY-MM-DD') + "T20:30:00.000Z"
timeInterval = [p_t, s_t]
}
GitHub 加速计划 / vu / vue
207.54 K
33.66 K
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:2 个月前 )
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 4 个月前
e428d891
Updated Browser Compatibility reference. The previous currently returns HTTP 404. 5 个月前
更多推荐
已为社区贡献1条内容
所有评论(0)