vue中通过时间戳格式化时间

后台传过来long类型的时间戳在vue中格式化成指定类型

  • 编写写时间格式化函数
export function _dateFormat(date,fmt) {
    var o = {
        "M+" : date.getMonth()+1,                 //月份
        "d+" : date.getDate(),                    //日
        "h+" : date.getHours(),                   //小时
        "m+" : date.getMinutes(),                 //分
        "s+" : date.getSeconds(),                 //秒
        "q+" : Math.floor((date.getMonth()+3)/3), //季度
        "S"  : date.getMilliseconds()             //毫秒
      };
    
      if(/(y+)/.test(fmt)){
        fmt=fmt.replace(RegExp.$1, (date.getFullYear()+"").substr(4 - RegExp.$1.length));
      }
            
      for(var k in o){
        if(new RegExp("("+ k +")").test(fmt)){
          fmt = fmt.replace(
            RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));  
        }       
      }
    
      return fmt;
}
  • 在组件中引入该函数
import {_dateFormat} from "../../utils/dateFormat"
  • 需要通过vue的filter来过滤
filters:{
    //格式化后台传过来的时间戳
    dateFormat(time) {
      let date = new Date(time);
      return _dateFormat(date,'yyyy-MM-dd hh:mm')
    }
  }
  • 最后在页面中使用
 <!-- 发布时间 -->
   <span>
     <i class="iconfont" style="font-size:14px;">&#xe619;</i>
     <em>&nbsp;{{article.gmtCreate | dateFormat}}</em>
   </span>

总结

  • 若是在页面中直接调用编写的时间格式化工具函数_dateFormat()是不行的,前台报以下错误
    在这里插入图片描述
    在这里插入图片描述
    描述:
    属性或方法“_dateFormat”不在实例上定义,而是在呈现期间引用。通过初始化该属性,确保该属性是反应性的,无论是在data选项中,还是对于基于类的组件。

    是因为由于Vue不允许动态添加根级反应属性,因此必须通过预先声明所有根级反应数据属性来初始化Vue实例,所以可以通过vue的filter过滤器来初始化引入的时间格式化函数_dateFormat()

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值