我个人在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 是 获取的时间戳,
这样就可以很容易的实现了时间戳的转换了

Logo

前往低代码交流专区

更多推荐