项目开发中,由于后台返回的数据是时间戳,所以前台需要有一哥统一处理日期。
举例:后台返回时间戳:1544942468922
Date.Transfer(time).Format('yyyy-MM-dd', /*optional*/ nullValueShow)
Transfer将时间戳转换成Date类型,Format第一个参数为日期格式,第二个参数为可选,当日期为null/undefined,需要显示的文字信息。
/** * Util.js */ // date原型链对象添加format方法,用于format日期格式 Date.prototype.Format = function (fmt) { var o = { 'M+': this.getMonth() + 1, // 月份 'd+': this.getDate(), // 日 'h+': this.getHours(), // 小时 'm+': this.getMinutes(), // 分 's+': this.getSeconds(), // 秒 'q+': Math.floor((this.getMonth() + 3) / 3), // 季度 'S': this.getMilliseconds() // 毫秒 } if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (this.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 } // Date对象Transfer对象,将时间戳转换成日期对象 Date.Transfer = function (timeSpan) { if (!timeSpan) { return new FormatDateNullValue() } return new Date(timeSpan) } // 创建对象用于date为null值的format function FormatDateNullValue () { } FormatDateNullValue.prototype.Format = function (date, value) { if (value) return value return '无' }
<template> <!-- 父组件 --> <div class="app-container"> <h3>{{Date.Transfer(time).Format('yyyy-MM-dd')}}</h3> <h3>{{Date.Transfer(timeNUll).Format('yyyy-MM-dd')}}</h3> <h3>{{Date.Transfer(timeCustomerNullValue).Format('yyyy-MM-dd', '自定义无值情况下显示的值')}}</h3> </div> </template> <script> import './Utils' export default { components: { }, mounted() {}, data() { return { time: 1544942468922, timeNUll: null, timeCustomerNullValue: null }; } }; </script> <style lang="scss" scoped> </style>
写完以后本以为可以使用了,可惜eslint的检测里有着不允许在Date.prototype操作,也是尴尬。
所以只有修改代码了:
/** * Util.js */ // date原型链对象添加format方法,用于format日期格式 var transfer = function (fmt) { var o = { 'M+': this.getMonth() + 1, // 月份 'd+': this.getDate(), // 日 'h+': this.getHours(), // 小时 'm+': this.getMinutes(), // 分 's+': this.getSeconds(), // 秒 'q+': Math.floor((this.getMonth() + 3) / 3), // 季度 'S': this.getMilliseconds() // 毫秒 } if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (this.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 } // Date对象Transfer对象,将时间戳转换成日期对象 Date.CustomerDateFormat = function (timeSpan, fmt, formatDateNullValue) { if (!timeSpan) { if (formatDateNullValue) { return formatDateNullValue } return '无' } var date = new Date(timeSpan) return transfer.call(date, fmt) }
<template> <!-- 父组件 --> <div class="app-container"> <h3>{{Date.CustomerDateFormat(time, 'yyyy-MM-dd')}}</h3> <h3>{{Date.CustomerDateFormat(timeNUll, 'yyyy-MM-dd')}}</h3> <h3>{{Date.CustomerDateFormat(timeCustomerNullValue, 'yyyy-MM-dd', '自定义无值情况下显示的值')}}</h3> </div> </template> <script> import './Utils' export default { components: { }, mounted() {}, data() { return { time: 1544942468922, timeNUll: null, timeCustomerNullValue: null }; } }; </script> <style lang="scss" scoped> </style>
写完,还要去公司加个班。