我個人在vue項目中遇到的時間戳轉換問題,是把轉換時間戳單獨作爲一個js文件,需要用的地方直接引用,這樣就不用多次在代碼中去寫了;
一、新建js文件
文件命名可以自己隨便命名,這裏就已 util.js 爲例
我是把此文件放入 /assets/js 文件夾裏
util.js 文件內容如下:
export function formatDate(date, fmt) {
if (/(y+)/.test(fmt)) {
fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length))
}
let o = {
'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 : padLeftZero(str))
}
}
return fmt
}
function padLeftZero(str) {
return ('00' + str).substr(str.length)
}
二、引用
引入到自己需要用的vue文件中
import { formatDate } from '@/assets/js/util';
在 export default{ } 中 新建方法;
// 轉換時間戳
filters: {
formatDate(time) {
time = time * 1000
let date = new Date(time)
return formatDate(date, 'yyyy-MM-dd hh:mm:ss')
}
},
當然 這裏 可以選擇自己 需要的時間格式,只要修改 ‘yyyy-MM-dd hh:mm:ss’ 的格式就好了;
方法的使用
在模板中需要轉換時間戳的地方按一下格式寫,
{{detailList.scheduled_time | formatDate}}
這裏 detailList.scheduled_time 是 獲取的時間戳,
這樣就可以很容易的實現了時間戳的轉換了