antd-vue的select组件实现既可以输入添加,又可以下拉选择

本文介绍如何使用Ant Design Vue的Select组件实现从下拉选项中选择或手动输入创建新的任务类型。通过监听搜索框的值变化和选中项的变更,结合后台返回的数据动态更新选项。同时展示了相关的方法实现,包括值变化回调、失焦事件处理。注意,模糊查询功能需要额外实现。

最近,项目中碰到需求,要求任务类型可以从下拉框(后台返回的数据)中选择,也可以手动输入添加新项,项目用的是antd-vue,所以最接近的组件就是a-select组件了,废话不多说,改造方法如下:

HTML:

复制代码

 1 
15             
16               {{ item.work_type }}
17             
18           

复制代码

data定义:

1 data () {
2       return {
3         value:undefined,
4         typeData:[],//任务类型数组
5       }
6 }

methods方法:

复制代码

 1  /**
 2        * @function 任务类型文本框的值变化时的回调
 3        * @author ***
 4        * @time 2020-08-17
 5        **/
 6       handleSearch (value) {
 7         this.handleChange(value);
 8       },
 9       /**
10        * @function 任务类型改变时的回调
11        * @author ***
12        * @time 2020-08-17
13        **/
14       handleChange (value) {
15         this.value = (!isNaN(value)&&value!='')?this.typeData[value].work_type:value;
16       },
17       /**
18        * @function 任务类型失焦事件
19        * @author ***
20        * @time 2020-08-17
21        **/
22       handleBlur(value) {
23         this.value=value;
24         this.model.workType = this.value;
25       },

复制代码

后台接口返回的数据如下:

效果图如下:

PS:模糊查询功能请自行完善

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值