项目中需要将接口返回的时间戳转换为2019-10-08格式,虽然简单,但也让自己浪费了很多时间,做下记录,方便以后使用
在公共js中添加以下代码
export function formatDate (date, fmt) {
if (/(y+)/.test(fmt)) {
fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)) } console.log('fmt') console.log(fmt) 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) } export default {
formatDate }
以上为封装的时间类
下面是具体组件中的调用方法
首先引用formatDate
import {
formatDate } from '../../utils/common'
使用formatDate
var date = new Date(time) return formatDate(date, 'yyyy-MM-dd')
在这里遇到一个坑,后台返回数据为 create_time:
<el-table-column prop="create_time" label="入职时间" width="120" :formatter="formatDate"></el-table-column>
我这里在表格中引用这个值,并用:formatter=”formatDate”进行修改
// 入职时间转换 formatDate (row, column) {
var date = new Date(row.create_time * 1000) return formatDate(date, 'yyyy-MM-dd') }
开始的时候我直接用的
var date = new Date(row.create_time)
返回值为1970年,起初以为后台接口的坑,最后才发现自己的问题,记录下。。。。
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/178395.html原文链接:https://javaforall.net
