ion-datetime 时间格式问题、要求的的时间格式(xxxx-xx-xx)在 IOS 中不兼容

目录

1. 场景

2. 思考

3. 扩展


1. 场景

将 ion-datetime 封装成组件:

  1. 使用两个 ion-datetime 分别接受开始时间(A)、结束时间(B)
  2. 给 A 传入 new Date().toISOString(),给 B 传入 new Date(new Date().getTime() + 24 * 60 * 60 * 1000).toISOString()
  3. 给 B 设置 min 属性

在不先选择开始时间,而是先选择结束时间的情况下,会报错:

<template>
  <ion-list>
    <ion-item>
      <ion-label>开始时间:</ion-label>
      <ion-datetime
        cancel-text="取消"
        done-text="确定"
        display-format="YYYY年MM月DD日"
        picker-format="YYYY MM DD"
        v-model="startTime"
        @ion-change="changeValue"
      ></ion-datetime>
    </ion-item>
    <ion-item>
      <ion-label>结束时间:</ion-label>
      <ion-datetime
        cancel-text="取消"
        done-text="确定"
        display-format="YYYY年MM月DD日"
        v-model="endTime"
        :min="startTime"
        @ion-change="changeValue"
      ></ion-datetime>
    </ion-item>
  </ion-list>
</template>

<script lang="ts">
import {
   defineComponent,
} from 'vue';
import { reactive, toRefs } from '@vue/reactivity';
import { IonList, IonItem, IonDatetime, IonLabel } from '@ionic/vue';
import { PropType } from '@vue/runtime-core';
import { SolidSourceDetailQuerydateScopeProps } from '@/types/map/solid-source-detail';

export default defineComponent({
  name: 'DateScope',
  components: {
    IonList,
    IonItem,
    IonDatetime,
    IonLabel,
  },
  props: {
    params: {
      type: Object as PropType<SolidSourceDetailQuerydateScopeProps>,
      default: () => ({
        paramName: 'dateScope',
        defaultValue: [
          new Date().toISOString(),
          new Date(new Date().getTime() + 24 * 60 * 60 * 1000).toISOString(),
        ],
      }),
    }
  },
  emits: ['change-value'],
  setup(props, { emit }) {
    const state = reactive({
      // 开始时间
      startTime: props.params.defaultValue[0],
      // 结束时间
      endTime: props.params.defaultValue[1],
    });

    /**
     * 改变值
     */
    function changeValue() {
      // 传参
      const params = {
        [props.params.paramName]: `${state.startTime},${state.endTime}`,
      };
      emit('change-value', params);
    }
    return {
      ...toRefs(state),
      changeValue,
    };
  },
});
</script>

2. 思考

这是由于 默认传入的日期格式 不对

当没有先选择开始日期时,传入的是默认日期(未经处理的 new Date(),而不是经过处理的 xxxx-xx-xx)

接口返回的日期格式为 '2021-11-15 23:00:00',格式化为 '2021-11-15' 即可

3. 扩展

IOS 中,不支持以 “-” 分割的 时间格式(例如:2021-12-02)

注意将 时间格式 使用 “/” 进行分割(例如:2021/12/02)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lyrelion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值