a-select:下拉组件实现筛选+远程搜索功能——基础积累

a-select:下拉组件实现筛选+远程搜索功能——基础积累

效果图

在这里插入图片描述

下拉筛选数据:

 <a-select
  show-search
  v-model="form.jobPositionCode"
  placeholder="请选择岗位"
  style="width: 100%"
  @change="jobChange"
  :filter-option="filterOption"
>
  <a-select-option
    v-for="li in jobPositionList"
    :key="li.code"
    :value="li.code"
    >{{ li.displayText }}</a-select-option
  >
</a-select>
filterOption(input, option) {
 return (
    option.componentOptions.children[0].text
      .toLowerCase()
      .indexOf(input.toLowerCase()) >= 0
  );
},

远程搜索功能:

<a-select
  show-search
  v-model="form.executorId"
  placeholder="请选择人员"
  style="width: 100%"
  :filter-option="false"
  @search="getUser"
  @change="userChange"
>
  <a-select-option
    v-for="li in userList"
    :key="li.id"
    :value="li.id"
    >{{ li.userName }}</a-select-option
  >
</a-select>
debounce(callback, delay = 200) {
  clearTimeout(this.timeout);
  this.timeout = setTimeout(() => {
    callback();
  }, delay);
},
userChange(val) {
  this.form.executorName = null;
   let obj = this.userList.find((item) => item.id == val);
   if (obj && obj.id) {
     this.form.executorName = obj.userName;
     this.$forceUpdate();
   }
 },
 getUser(val) {
   this.debounce(() => {
     let params = {
       Filter: val,
       current: 1,
       pageSize: 50,
     };
     this.fetchUser(params);
   });
 },
 fetchUser(params) {
   getList(params).then((data) => {
     if (data.success) {
       this.userList = data.result.items || [];
     }
   });
 },
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

叶浩成520

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

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

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

打赏作者

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

抵扣说明:

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

余额充值