聊天记录 列表显示时间+聊天框显示时间
一分钟:显示刚刚
一小时内:显示多少分钟之前
今日:显示小时+分钟
昨日:显示 昨天+小时+分钟
今年:显示:月份+日期
不属于今年:显示:年月日+小时+分钟
代码逻辑
以下函数都写在comment.js文件下
主函数
解释:
聊天的时间逻辑
传递 timeValue的格式为 2021/03/24 13:56:00
如果数据是'2015-08-18 15:13:15';参考下述进行转换
// var str ='2015-08-18 15:13:15';
// str = str.replace(/-/g,"/");
// var date = new Date(str );
function timeChange (timeValue) {
timeValue = new Date(timeValue).getTime()
var timeNew = new Date().getTime() // 当前时间
// console.log('传入的时间', timeValue, timeNew)
var timeDiffer = timeNew - timeValue // 与当前时间误差
// console.log('时间差', timeDiffer)
var returnTime = ''
if (timeDiffer <= 60000) { // 一分钟内
returnTime = '刚刚'
} else if (timeDiffer > 60000 && timeDiffer < 3600000) { // 1小时内
returnTime = Math.floor(timeDiffer / 60000) + '分钟前'
} else if (timeDiffer >= 3600000 && timeDiffer < 86400000 && isYestday(timeValue) === false) { // 今日
returnTime = formatTime(timeValue).substr(11, 5)
} else if (timeDiffer > 3600000 && isYestday(timeValue) === true) { // 昨天
returnTime = '昨天' + formatTime(timeValue).substr(11, 5)
} else if (timeDiffer > 86400000 && isYestday(timeValue) === false && isYear(timeValue) === true) { // 今年
returnTime = formatTime(timeValue).substr(5, 11)
} else if (timeDiffer > 86400000 && isYestday(timeValue) === false && isYear(timeValue) === false) { // 不属于今年
returnTime = formatTime(timeValue).substr(0, 16)
}
return returnTime
}
次函数
函数isYestday:是否为昨天 返回 true or false
这里根据日期进行判断,而非时间戳数值,因为数值计算涉及到大数有一定的误差
function isYestday (timeValue) { // 是否为昨天
const date = new Date(timeValue)
const today = new Date()
if (date.getFullYear() === today.getFullYear() && date.getMonth() === today.getMonth()) {
if (date.getDate() - today.getDate() === 1) {
return true
} else {
return false
}
} else {
return false
}
}
function isYear (timeValue) { // 是否为今年
const dateyear = new Date(timeValue).getFullYear()
const toyear = new Date().getFullYear()
// console.log(dateyear, toyear)
if (dateyear === toyear) {
return true
} else {
return false
}
}
函数:formatTime 格式化时间 返回时间字符串如 2018-07-06 11:11:37
function formatTime (date) {
var t = getTimeArray(date)
return [t[0], t[1], t[2]].map(formatNumber).join('-') + ' ' + [t[3], t[4], t[5]].map(formatNumber).join(':')
}
function getTimeArray (date) {
date = new Date(date)
var year = date.getFullYear()
var month = date.getMonth() + 1
var day = date.getDate()
var hour = date.getHours()
var minute = date.getMinutes()
var second = date.getSeconds()
return [year, month, day, hour, minute, second].map(formatNumber)
}
// 转化日期 如2018-7-6 -->(2018-07-06)
function formatNumber (n) {
n = n.toString()
return n[1] ? n : '0' + n
}