el-select 远程搜索 实战 使用

 <el-form-item label="邮政编码" prop="zipCode">
      <el-select
        v-model="form.zipCode"
        remote
        clearable
        filterable
        reserve-keyword
        :remote-method="remoteMethod"
        placeholder="请选择"
        default-first-option
        @change="zipCodeChange"
      >
        <el-option
          v-for="item in candidates"
          :key="item.value"
          :label="item.countryCode + ' ' + item.state + ' ' + item.city + ' ' + item.zipCode"
          :value="item.id"
        >
        </el-option>
      </el-select>
    </el-form-item>

return:{
     form: {
        countryCode: '',
        zipCode: '',
        province: '',
        city: '',
        address: '',
        address2: '',
        contacts: '',
        phone: '',
        company: ''
      },
      candidates: [],
      findItemCode: ''
}


methods:{
       remoteMethod (query) {
      if (!query || !this.form.countryCode) return (this.candidates = [])
      setTimeout(async () => {
        const res = await this.$request({
          url: `/deliverAddress/candidate?zipcode=` + query + '&countryCode=' + this.form.countryCode,
          method: 'get'
        })
        this.candidates = res.data
      }, 1500)
    },

    zipCodeChange (e) {
      if (!e) return
      let findItem = this.candidates.find((item) => item.id === e)
      if (!findItem) return this.$message.warning('发生未知错误,请重新选择!')
      this.findItemCode = findItem
      this.form.province = findItem.state
      this.form.city = findItem.city
    }
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
form generator是一个表单生成器,可以帮助我们快速生成各种表单元素。而el-selectelement-ui框架中的一个下拉选择组件。要扩展el-select远程搜索功能,我们可以按照以下步骤进行。 首先,在form generator的代码中找到生成el-select组件的部分。一般来说,我们可以为el-select设置一个远程搜索的属性,比如remote-search。然后,在该属性的处理逻辑中,我们可以使用element-ui提供的el-autocomplete组件,实现远程搜索的功能。 其次,为了实现远程搜索,我们需要在el-select远程搜索事件中发送Ajax请求。可以使用Vue.js提供的axios库或者使用element-ui的el-request库来发送请求。在请求中,我们需要传递远程搜索的关键字,一般是通过输入框实时获取用户输入的值。将这个关键字发送到后台,进行搜索操作。搜索的结果可以是JSON格式的数据,包含了符合条件的选项。 最后,当接收到后台返回的搜索结果后,我们可以根据结果来更新el-select的下拉选项列表。可以通过修改el-select的options属性来实现。将搜索结果的数据添加到options列表中,然后重新渲染el-select,用户就可以看到符合搜索条件的选项。 综上所述,要扩展form generator中的el-select远程搜索功能,我们需要为el-select添加一个remote-search属性,处理该属性对应的远程搜索逻辑,并在搜索结果返回后更新el-select的下拉选项列表。这样,用户在使用表单生成器时可以方便地使用el-select远程搜索功能,提高了表单的灵活性和用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值