Vant 4中的van-picker选择总是第一个的解决办法

Vant 4中的van-picker选择总是第一个的解决办法

官方demo

javascript 复制代码
<van-field
  v-model="fieldValue"
  is-link
  readonly
  label="城市"
  placeholder="选择城市"
  @click="showPicker = true"
/>
<van-popup v-model:show="showPicker" round position="bottom">
  <van-picker
    :columns="columns"
    @cancel="showPicker = false"
    @confirm="onConfirm"
  />
</van-popup>
import { ref } from 'vue';

export default {
  setup() {
    const columns = [
      { text: '杭州', value: 'Hangzhou' },
      { text: '宁波', value: 'Ningbo' },
      { text: '温州', value: 'Wenzhou' },
      { text: '绍兴', value: 'Shaoxing' },
      { text: '湖州', value: 'Huzhou' },
    ];
    const fieldValue = ref('');
    const showPicker = ref(false);

    const onConfirm = ({ selectedOptions }) => {
      showPicker.value = false;
      fieldValue.value = selectedOptions[0].text;
    };

    return {
      columns,
      onConfirm,
      fieldValue,
      showPicker,
    };
  },
};

渲染出来的结果是这样的

这个使用起来是没啥问题的

他默认是渲染text,但是一般在我们使用中99%的数据渲染都不可能是text,这个时候就可以使用文档中的columns-field-names来自定义自定义 columns 结构中的字段,比如我们的数据里面现在是name为需要渲染的字段就可以这么写

javascript 复制代码
<van-picker
        :columns-field-names="{ text: 'name'}"
        :columns="columns"
        @cancel="showPicker = false"
        @confirm="onConfirm"
      >
</van-picker>

但是这个时候就会发现一个问题,就是不管你怎么选择都是第一个选项,因为我也是个前端小白,找了蛮久都没找到解决办法,后来试了一下自定义value居然可以,所以就可以写成

javascript 复制代码
:columns-field-names="{ text: 'name', value: 'name' }"

这样就可以了,也不知道为啥,看不懂源码

为啥一开始不自定义value,因为我想获取的是选择的这个对象,不是这个对象里面的某个属性

相关推荐
阿里巴啦2 分钟前
照片隐私清理工具:基于Taro 4 + Vue 3 + piexifjs开发实践项目
vue.js·照片隐私清除·piexifjs·exif 解析
贾修行3 分钟前
Kestrel:.NET 的高性能 Web 服务器探秘
服务器·前端·kestrel·.net·net core·web-server·asp.net-core
吃吃喝喝小朋友4 分钟前
HTML DOM
前端·javascript·html
HWL56794 分钟前
HTML中,<video> 和 <source> 标签
前端·javascript·html
球球不吃虾4 分钟前
分享一个简单的交互式塔罗牌抽牌应用
前端·vue
2501_948120156 分钟前
中职动漫设计与制作专业实训方案研究
前端·人工智能·语言模型·自然语言处理·架构
小小鸟0087 分钟前
前端 RBAC基于角色的权限控制(按钮级别)
前端
学习java的小库里8 分钟前
EasyExcel复杂导出
java·前端
muddjsv9 分钟前
前端开发通用全流程:从需求到上线,步步拆解
前端
Mr Xu_15 分钟前
从零实战!使用 Mars3D 快速构建水利监测 WebGIS 系统
前端·3d·webgis