uniapp踩坑之项目:使用过滤器将时间格式化为特定格式
2023-12-13 05:29:53
利用filters过滤器对数据直接进行格式化,注意:与method、onLoad、data同层级
<template>
<div>
<!-- orderInfo.time的数据为:2023-12-12 12:10:23 -->
<p>{{ orderInfo.time | formatDate }}</p> <!-- 2023-12-12 -->
<p>{{ orderInfo.time | formatTime }}</p> <!-- 12:10:23 -->
<p>{{ orderInfo.time | formatDateTime }}</p> <!-- 2023-12-12 12:10:23 -->
</div>
</template>
<script>
export default {
data() {
return {
orderInfo: [],
}
},
onLoad (options) {
if (options.id) {
let Id = options.id
this.接口({ Id }).then(res => {
this.orderInfo = res.data.data
})
}
},
// 过滤器
filters: {
formatDate (value) {
// ios部分机型无法识别版
// const date = new Date(value);
// return date.getFullYear()+'-'+(date.getMonth()+1)+'-'+date.getDate();
// 兼容版
if (value != undefined) {
return value.substring(0, value.indexOf(' '))
}
},
formatTime (value) {
// ios部分机型无法识别版
// const time = new Date(value);
// return time.getHours() + ":" + time.getMinutes() + ":" + time.getSeconds();
// 兼容版
if (value != undefined) {
const year = value.substr(0, 4); // 年
const index = value.indexOf("-");
const lastIndex = value.lastIndexOf("-");
let interval = parseInt(lastIndex) - (parseInt(index) + 1); // 间隔
const month = value.substr((parseInt(index) + 1), interval); // 月
let space = value.indexOf(" "); // 空格
interval = parseInt(space) - parseInt(lastIndex);
const day = value.substr(parseInt(lastIndex) + 1, interval); // 日
let colon = value.indexOf(":"); // 冒号
interval = parseInt(colon) - (parseInt(space) + 1);
const hour = value.substr(parseInt(space) + 1, interval);
const colon2 = value.lastIndexOf(":");
interval = parseInt(colon2) - (parseInt(colon) + 1);
const minutes = value.substr(parseInt(colon) + 1, interval);
const colon3 = value.lastIndexOf(":");
const seconds = value.substr(parseInt(colon3) + 1);
return hour + ":" + minutes + ":" + seconds; // 时分秒
}
},
formatDateTime (value) {
// ios部分机型无法识别版
// const datetime = new Date(value);
// const date = datetime.getFullYear()+'-'+(datetime.getMonth()+1)+'-'+datetime.getDate();
// const time = datetime.getHours() + ":" + datetime.getMinutes() + ":" + datetime.getSeconds();
// return date + ' ' + time;
// 兼容版
if (value != undefined) {
const year = value.substr(0, 4); // 年
const index = value.indexOf("-");
const lastIndex = value.lastIndexOf("-");
let interval = parseInt(lastIndex) - (parseInt(index) + 1); // 间隔
const month = value.substr((parseInt(index) + 1), interval); // 月
let space = value.indexOf(" "); // 空格
interval = parseInt(space) - parseInt(lastIndex);
const day = value.substr(parseInt(lastIndex) + 1, interval); // 日
let colon = value.indexOf(":"); // 冒号
interval = parseInt(colon) - (parseInt(space) + 1);
const hour = value.substr(parseInt(space) + 1, interval);
const colon2 = value.lastIndexOf(":");
interval = parseInt(colon2) - (parseInt(colon) + 1);
const minutes = value.substr(parseInt(colon) + 1, interval);
const colon3 = value.lastIndexOf(":");
const seconds = value.substr(parseInt(colon3) + 1);
return year + "-" + month + "-" + day + hour + ":" + minutes + ":" + seconds; // 年月日时分秒
}
}
}
}
</script>
上一篇文章,?
文章来源:https://blog.csdn.net/weixin_43928112/article/details/134807024
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!