vant中的Calendar日历组件type=range时默认当天回显问题

<van-calendar type="range" :allow-same-day="true" :default-date="defaultDate" />

<script setup lang="ts">
    import { ref } from 'vue';
    const defaultDate = ref([new Date(), new Date()]);
</script>

然后会发现日历默认选中的并不是今天-今天,而是今天-明天。后面经过坚持不懈的搜索及尝试,找到了解决方案:

<van-calendar type="range" :allow-same-day="true" :default-date="defaultDate" />

<script setup lang="ts">
    import { ref, onMounted } from 'vue';
    const defaultDate = ref([]);

    onMounted(() => {
        defaultDate.value = [new Date(), new Date()];
    });
</script>

原因是Calendar组件的allow-same-day参数默认值是false,即不允许日期范围的起止时间为同一天,所以一开始初始化赋予起止为同一天是无效的。需要等页面元素渲染完成之后(onMounted)再进行赋值,这时候日历的回显的默认值就是今天-今天啦!完美撒花~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值