Commit de30f1b30d987810d1d7e157bc5ae8a6a8cd8b9a
1 parent
468bde3c
update Time func
Showing
2 changed files
with
79 additions
and
91 deletions
Show diff stats
examples/routers/time.vue
| @@ -2,14 +2,14 @@ | @@ -2,14 +2,14 @@ | ||
| 2 | <div> | 2 | <div> |
| 3 | <Time :time="1526608921" /> | 3 | <Time :time="1526608921" /> |
| 4 | <Time :time="1652839997" /> | 4 | <Time :time="1652839997" /> |
| 5 | - <Time :time="ddd" /> | 5 | + <Time :time="ddd" interval="1" /> |
| 6 | </div> | 6 | </div> |
| 7 | </template> | 7 | </template> |
| 8 | <script> | 8 | <script> |
| 9 | export default { | 9 | export default { |
| 10 | data () { | 10 | data () { |
| 11 | return { | 11 | return { |
| 12 | - ddd: new Date('2018-01-01') | 12 | + ddd: new Date('2019-05-28 14:12:00') |
| 13 | }; | 13 | }; |
| 14 | }, | 14 | }, |
| 15 | computed: {}, | 15 | computed: {}, |
src/components/time/time.js
| 1 | -const time = { | ||
| 2 | - getUnix (place) { | ||
| 3 | - const date = new Date(); | ||
| 4 | - const timestamp = date.getTime(); // 得到的是毫秒 | 1 | +/** |
| 2 | + * @param {Number} timeStamp 判断时间戳格式是否是毫秒 | ||
| 3 | + * @returns {Boolean} | ||
| 4 | + */ | ||
| 5 | +// const isMillisecond = timeStamp => { | ||
| 6 | +// const timeStr = String(timeStamp); | ||
| 7 | +// return timeStr.length > 10; | ||
| 8 | +// }; | ||
| 5 | 9 | ||
| 6 | - if (place === 's') { // 秒 | ||
| 7 | - return Math.floor(timestamp / 1000); | ||
| 8 | - } else { // 毫秒 | ||
| 9 | - return timestamp; | ||
| 10 | - } | ||
| 11 | - }, | ||
| 12 | - getToday (place) { | ||
| 13 | - const today = new Date(); | ||
| 14 | - const year = today.getFullYear(); | ||
| 15 | - const month = today.getMonth() + 1; | ||
| 16 | - const day = today.getDate(); | ||
| 17 | - const hours = 0; | ||
| 18 | - const mins = 0; | ||
| 19 | - const secs = 0; | ||
| 20 | - const datetime = year + '-' + month + '-' + day + ' ' + hours + ':' + mins + ':' + secs; | ||
| 21 | - let tmp_datetime = datetime.replace(/:/g,'-'); | ||
| 22 | - tmp_datetime = tmp_datetime.replace(/ /g,'-'); | ||
| 23 | - const arr = tmp_datetime.split('-'); | ||
| 24 | - const now = new Date(Date.UTC(arr[0],arr[1]-1,arr[2],arr[3]-8,arr[4],arr[5])); | ||
| 25 | - | ||
| 26 | - if (place === 's') { | ||
| 27 | - return parseInt(now.getTime() / 1000); | ||
| 28 | - } else { | ||
| 29 | - return parseInt(now.getTime()); | ||
| 30 | - } | ||
| 31 | - }, | ||
| 32 | - getYear (place) { | ||
| 33 | - const today = new Date(); | ||
| 34 | - const year = today.getFullYear(); | ||
| 35 | - const month = 0; | ||
| 36 | - const day = 1; | ||
| 37 | - const hours = 0; | ||
| 38 | - const mins = 0; | ||
| 39 | - const secs = 0; | ||
| 40 | - const datetime = year + '-' + month + '-' + day + ' ' + hours + ':' + mins + ':' + secs; | ||
| 41 | - let tmp_datetime = datetime.replace(/:/g,'-'); | ||
| 42 | - tmp_datetime = tmp_datetime.replace(/ /g,'-'); | ||
| 43 | - const arr = tmp_datetime.split('-'); | ||
| 44 | - const now = new Date(Date.UTC(arr[0],arr[1]-1,arr[2],arr[3]-8,arr[4],arr[5])); | ||
| 45 | - if (place === 's') { | ||
| 46 | - return parseInt(now.getTime() / 1000); | ||
| 47 | - } else { | ||
| 48 | - return parseInt(now.getTime()); | ||
| 49 | - } | ||
| 50 | - }, | ||
| 51 | - getLastDate (time, type) { | ||
| 52 | - const unixtime = time * 1000; | ||
| 53 | - const date = new Date(unixtime); | ||
| 54 | - const month = date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1; | ||
| 55 | - const currentDate = date.getDate() < 10 ? '0' + date.getDate() : date.getDate(); | ||
| 56 | - const hh = date.getHours() < 10 ? '0' + date.getHours() : date.getHours(); | ||
| 57 | - const mm = date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes(); | ||
| 58 | - // const ss = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds(); | 10 | +/** |
| 11 | + * @param {Number} timeStamp 传入的时间戳 | ||
| 12 | + * @param {Number} currentTime 当前时间时间戳 | ||
| 13 | + * @returns {Boolean} 传入的时间戳是否早于当前时间戳 | ||
| 14 | + */ | ||
| 15 | +const isEarly = (timeStamp, currentTime) => { | ||
| 16 | + return timeStamp < currentTime; | ||
| 17 | +}; | ||
| 59 | 18 | ||
| 60 | - if (type === 'month') { | ||
| 61 | - return month + '-' + currentDate + ' ' + hh + ':' + mm; | ||
| 62 | - //return month + "-" + currentDate; | ||
| 63 | - } else { | ||
| 64 | - return date.getFullYear() + '-' + month + '-' + currentDate + ' ' + hh + ':' + mm; | ||
| 65 | - } | ||
| 66 | - }, | ||
| 67 | - // 时间戳转详细时间,比如5分钟前 | ||
| 68 | - getMagic (timestamp) { | ||
| 69 | - const now = this.getUnix('s'); //当前时间戳 | ||
| 70 | - const today = this.getToday('s'); //今天0点时间戳 | ||
| 71 | - const year = this.getYear('s'); //今年0点时间戳 | ||
| 72 | - const timer = now - timestamp; | 19 | +/** |
| 20 | + * @param {Number} num 数值 | ||
| 21 | + * @returns {String} 处理后的字符串 | ||
| 22 | + * @description 如果传入的数值小于10,即位数只有1位,则在前面补充0 | ||
| 23 | + */ | ||
| 24 | +const getHandledValue = num => { | ||
| 25 | + return num < 10 ? '0' + num : num; | ||
| 26 | +}; | ||
| 73 | 27 | ||
| 74 | - let tip = ''; | 28 | +/** |
| 29 | + * @param {Number} timeStamp 传入的时间戳 | ||
| 30 | + * @param {Number} startType 要返回的时间字符串的格式类型,传入'year'则返回年开头的完整时间 | ||
| 31 | + */ | ||
| 32 | +const getDate = (timeStamp, startType) => { | ||
| 33 | + const d = new Date(timeStamp * 1000); | ||
| 34 | + const year = d.getFullYear(); | ||
| 35 | + const month = getHandledValue(d.getMonth() + 1); | ||
| 36 | + const date = getHandledValue(d.getDate()); | ||
| 37 | + const hours = getHandledValue(d.getHours()); | ||
| 38 | + const minutes = getHandledValue(d.getMinutes()); | ||
| 39 | + const second = getHandledValue(d.getSeconds()); | ||
| 40 | + let resStr = ''; | ||
| 41 | + if (startType === 'year') resStr = year + '-' + month + '-' + date + ' ' + hours + ':' + minutes + ':' + second; | ||
| 42 | + else resStr = month + '-' + date + ' ' + hours + ':' + minutes; | ||
| 43 | + return resStr; | ||
| 44 | +}; | ||
| 75 | 45 | ||
| 76 | - if (timer <= 0) { | ||
| 77 | - tip = '刚刚'; | ||
| 78 | - } else if (Math.floor(timer/60) <= 0) { | ||
| 79 | - tip = '刚刚'; | ||
| 80 | - } else if (timer < 3600) { | ||
| 81 | - tip = Math.floor(timer/60) + '分钟前'; | ||
| 82 | - } else if (timer >= 3600 && (timestamp - today >= 0) ) { | ||
| 83 | - tip = Math.floor(timer/3600) + '小时前'; | ||
| 84 | - } else if (timer/86400 <= 31) { | ||
| 85 | - tip = Math.ceil(timer/86400) + '天前'; | ||
| 86 | - } else if (timestamp - today < 0 && (timestamp - year >= 0)) { | ||
| 87 | - tip = this.getLastDate(timestamp, 'month'); | ||
| 88 | - } else { | ||
| 89 | - tip = this.getLastDate(timestamp, 'year'); | ||
| 90 | - } | ||
| 91 | - return tip; | ||
| 92 | - } | 46 | +/** |
| 47 | + * @param {String|Number} timeStamp 时间戳 | ||
| 48 | + * @returns {String} 相对时间字符串 | ||
| 49 | + */ | ||
| 50 | +export const getRelativeTime = timeStamp => { | ||
| 51 | + // 判断当前传入的时间戳是秒格式还是毫秒 | ||
| 52 | + // const IS_MILLISECOND = isMillisecond(timeStamp); | ||
| 53 | + const IS_MILLISECOND = true; | ||
| 54 | + // 如果是毫秒格式则转为秒格式 | ||
| 55 | + if (IS_MILLISECOND) Math.floor(timeStamp /= 1000); | ||
| 56 | + // 传入的时间戳可以是数值或字符串类型,这里统一转为数值类型 | ||
| 57 | + timeStamp = Number(timeStamp); | ||
| 58 | + // 获取当前时间时间戳 | ||
| 59 | + const currentTime = Math.floor(Date.parse(new Date()) / 1000); | ||
| 60 | + // 判断传入时间戳是否早于当前时间戳 | ||
| 61 | + const IS_EARLY = isEarly(timeStamp, currentTime); | ||
| 62 | + // 获取两个时间戳差值 | ||
| 63 | + let diff = currentTime - timeStamp; | ||
| 64 | + // 如果IS_EARLY为false则差值取反 | ||
| 65 | + if (!IS_EARLY) diff = -diff; | ||
| 66 | + let resStr = ''; | ||
| 67 | + const dirStr = IS_EARLY ? '前' : '后'; | ||
| 68 | + // 少于等于59秒 | ||
| 69 | + if (diff <= 59) resStr = diff + '秒' + dirStr; | ||
| 70 | + // 多于59秒,少于等于59分钟59秒 | ||
| 71 | + else if (diff > 59 && diff <= 3599) resStr = Math.floor(diff / 60) + '分钟' + dirStr; | ||
| 72 | + // 多于59分钟59秒,少于等于23小时59分钟59秒 | ||
| 73 | + else if (diff > 3599 && diff <= 86399) resStr = Math.floor(diff / 3600) + '小时' + dirStr; | ||
| 74 | + // 多于23小时59分钟59秒,少于等于29天59分钟59秒 | ||
| 75 | + else if (diff > 86399 && diff <= 2623859) resStr = Math.floor(diff / 86400) + '天' + dirStr; | ||
| 76 | + // 多于29天59分钟59秒,少于364天23小时59分钟59秒 | ||
| 77 | + else if (diff > 2623859 && diff <= 31567859) resStr = getDate(timeStamp); | ||
| 78 | + // 多于364天23小时59分钟59秒 | ||
| 79 | + else resStr = getDate(timeStamp, 'year'); | ||
| 80 | + return resStr; | ||
| 93 | }; | 81 | }; |
| 94 | 82 | ||
| 95 | export default function (timestamp) { | 83 | export default function (timestamp) { |
| 96 | - return time.getMagic(timestamp / 1000); | 84 | + return getRelativeTime(timestamp); |
| 97 | } | 85 | } |
| 98 | \ No newline at end of file | 86 | \ No newline at end of file |