在使用 Vant 4 中, van-time-picker 在添加 filter 属性时选项消失遇到的问题

在尝试使用van-time-picker的filter属性过滤分钟选项时,作者遇到问题,分钟选项消失。经过调试发现,`option`不是一个可以直接转换为数字的字符串,而是包含`value`属性。修复代码为`Number(option.value)%15===0`,最终成功过滤并显示正确结果。
摘要由CSDN通过智能技术生成

想要在 van-time-picker 中使用 filter 属性过滤分钟的选项,

在网上搜了很多资料, 基本上都是以下写法:

const timeFilter = (type, options) => {
    if (type === 'minute') {
        return options.filter((option) => Number(option) % 15 === 0);
    }
    return options;
};

实际使用后, 却产生以下不是我想要的结果:

分钟的选项完全消失了...

继续上网搜, 为什么会发生这样的结果?

没有搜到讨论原因的资料, 虽然有人提供别的解决办法

但我想找到原因, 从头理解这个问题的本源

接着我开始思考, 其实那段代码基本上能出问题的地方就只有:

options.filter((option) => Number(option) % 15 === 0);

所以我用下面代码探究 option 究竟是什么资料结构:

console.log(option);

发现他是这样的: 

 

原来他压根就不是个能用 Number() 函数转成数字的 string 啊!!

但是由此可知要怎么正确取得分钟的数值了!!

让我们改一下之前的代码:

const timeFilter = (type, options) => {
    if (type === 'minute') {
        return options.filter((option) => Number(option.value) % 15 === 0);
    }
    return options;
};

来看一下代码修改之后, van-time-picker 显示的结果:

成功 !!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

重修全栈开发

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

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

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

打赏作者

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

抵扣说明:

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

余额充值