扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章给大家分享的是有关vue中怎么根据时间戳判断对应的时间的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联专注于企业全网营销推广、网站重做改版、桓台网站定制设计、自适应品牌网站建设、H5开发、购物商城网站建设、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为桓台等各大城市提供网站开发制作服务。根据时间戳 来显示对应的时间段
本文是根据vue缩写,但是原理都是想通的
根据一个时间戳,然后来显示对应的时间段。如果为今天,则显示对应的time,如果为昨天,则显示为昨天,如果为前天,则显示为前天。剩下的显示为对应的日期
需求定义好了,然后开始实现:
首先,是把时间戳转换为对应的时间格式,js提供了原生的获取对应年、月、日等格式的方法,但是不够灵活,这里提供了一个网上找的比较灵活获取固定格式的函数。
const formatDate = (date, fmt) => { date = new Date(date); if (typeof (fmt) === "undefined") { fmt = "yyyy-MM-dd HH:mm:ss"; } if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)) } let o = { 'Y': date.getFullYear(), 'M+': date.getMonth() + 1, 'd+': date.getDate(), 'H+': date.getHours(), 'm+': date.getMinutes(), 's+': date.getSeconds() } for (let k in o) { if (new RegExp(`(${k})`).test(fmt)) { let str = o[k] + '' fmt = fmt.replace(RegExp.$1, RegExp.$1.length === 1 ? str : ('00' + str).substr(str.length)); } } return fmt }
使用这个函数,需要提供一个时间戳和一个日期格式。
// `+new Date()` 为获取当前时间戳的简写形式 // `yyyy-MM-dd HH:mm:ss`为想要获取的日期格式 formatDate(+new Date(), 'yyyy-MM-dd HH:mm:ss') // 2019-12-18 20:29:31
接下来是使用过滤器来对时间戳进行过滤。vue提供了过滤器,可以定义全局过滤器和本地过滤器,我们定义一个本地过滤器
// common.js // 这里使用模块化,把过滤器函数定义在外部js文件内 const formatDate ...... export { formatDate } // index.vue import { formatDate } from 'common' export default { data () { return { time: 1576673222857 } }, methods: {}, created() {}, filters: { formateDate(data, fmt) { return formatDate(data, fmt) } } }
定义好了过滤器,就可以在页面中使用了
// index.vue
{{ time | formateDate('MM-dd') }}
使用|(管道符)来对时间戳进行过滤,管道符左侧为过滤器的第一个参数,第二个参数为过滤的格式。定义好之后就会根据格式显示对应的时间格式了。
接下来最后一步就是对比今天的日期,来显示对应的时间(昨天,前天)
这里使用vue的if else来判断应该显示哪种日期格式。
{{ time | formateDate('HH:mm') }} // 这里把时间戳转换为`日`,然后跟当前的`日`进行比较,如果相等,则说明是今天的时间戳,则显示`time` {{ time | formateDate('HH:mm') }} // 这里把**当前**的时间戳 `-1`,说明是昨天。比如说今天是18日,`-1`之后就是17,如果`time`转换后 与 17 相等,说明应该显示为`昨天`。 {{ time | formateDate('HH:mm') }} // `-2`为`前天` {{ time | formateDate('MM-dd') } // 否则显示为对应的日期
好了,以上是根据日期去比较来显示对应的时间。—— 但是,你以为完了吗?
有一个重要的问题就是,每个月都有30日中的其中一日,今天是12月18日,比较18相等,显示对应的时间,但是如果为11月18日呢?如果还显示对应的时间显然是不对了。
所以应该把年、月、日 全都对比一下,然后在确定对应的时间。
所以代码应该如下:
{{time | FormatDate( 'HH:mm')}} 昨天 前天 {{ time | formateDate('MM-dd') }
虽然是完成了比较年月日后,来显示对应的日期。但是看看这些代码巨丑无比,而且极不容易理解,所以,我们不应该在html里面写这么多判断代码,so,我们来封装成一个函数,然后在来使用函数对比。
在封装函数之前,我们先确定一下,上面这些判断代码中,有哪些相同的地方,哪些不同的地方。
相同的是
使用new Date(time) 来对比new Date()
使用getDate() / getMonth() / getYear()
使用两个&&来对比
不同的是
一个new Date()里面需要参数time,一个不要参数
有些需要-对应的数字
大概梳理了一下出以上部分,把相同的写进函数内,不同的使用形参,也就是arguments。
// common.js
const compareDate = (timestamp, day = 0) => { // timestamp 为要传入的时间戳 // day 为要减去的日子 因为比较*当天*的话,是不需要减的,所以默认定义成0, // 根据上面分析,有些需要参数`time`,有些不需要,所以使用一个函数来区分一下 let newDate = (time = null) => { return time === null ? new Date() : new Date(time) } // 这里返回 比较后的值,比较成功,则返回`true`,失败则返回`false` return (newDate(timestamp).getDate() == newDate().getDate() - day) && (newDate(timestamp).getMonth() == newDate().getMonth()) && (newDate(timestamp).getYear() == newDate().getYear()) } export { compareDate }
上面就是封装好的函数,但是有一个问题,就是函数里面写死了比较年月日,因为目前都需要比较三个,就先这样,有时间在改为根据参数在来区分比较年或月或日。
然后就可以使用了,使用的时候需要注意一下,我的这篇博客里面已经说了,这里就不细说, 直接放代码:
// index.vue import { compareDate } from 'common.js' data() { return { compare: compareDate } }{{time | FormatDate( 'HH:mm')}} 昨天 前天 {{time | FormatDate( 'MM-d')}}
这样是不是简洁了很多呢?,而且也容易理解,看着也清晰。
感谢各位的阅读!关于“vue中怎么根据时间戳判断对应的时间”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流