iView的Select 选择器选择失效

在Vue项目中遇到一个问题,当尝试将接口返回的数组list的第一个元素作为Select组件的默认值defaultValue时,Select的选择器切换选项出现失效或延迟响应。原因是defaultValue直接使用list[0]导致默认值与选项值引用了同一个对象。解决方法是创建一个新的对象副本,如defaultValue={...list[0]}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:给iView的Select赋的值通过接口获取,得到数组 list,选择器的默认值 defaultValue 为数组list的第一个选择项(defaultValue = list[0]),完成后选择器切换选项失效,或点击多次才生效。

<Select v-model="defaultValue">
        <Option v-for="item in list" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>

思路:defaultValue不赋值或直接赋值一个对象,无问题,所以应该是因为defaultValue不能直接用list中的值赋值,即不能使默认值与选项值的地址指向一致,为同一对象。

解决:defaultValue 赋值改为:defaultValue = { ...list[0] };   赋新对象,指向不一致,无问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值