element UI el-autocomplete 带输入建议的输入框

本文介绍了如何在Vue项目中利用element-ui的el-autocomplete组件,结合后台API,实现实时搜索公司全名的功能。通过监听输入框变化,调用querySearch方法获取后台数据,并自定义filter方法过滤数据,确保用户输入时显示匹配的公司名称。同时,文章还展示了如何处理数据转换,将筛选字段映射为value,以便于autocomplete组件使用。
摘要由CSDN通过智能技术生成

项目需求:需要用户在输入框中输入公司 全名    但是为了避免用户输入不全   需要做一个带输入建议的输入框

element组件:

el-autocomplete 

        class="inline-input"          

        v-model="state1"         

        placeholder="请输入内容"     

        :fetch-suggestions="querySearch"                       // fetch-suggestions 是一个返回输入建议的方法属性

         :trigger-on-focus="false"                                //  false = >输入后匹配输入建议  true => 激活即列出输入建议

        @select="handleSelect"                                 // 点击选中建议项时触发  handleSelect

>   

在输入框变化时 会触发  querySearch 函数    获取到当前输入的字段  然后调用 createFilter 函数 筛选数据

下图为官方写法  

官方写法将 全部数据 放在 loadAll 函数里   然后通过 createFilter 函数做筛选

而我需要从后台获取数据。

querySearch(queryString, cb) {   

        this.$http({

            url: this.$http.adornUrl("/sys/selct/companyname"),

            method: "post",

            params: this.$http.adornParams({

                    companyName:queryString 

             })

        }).then(({ data }) => {

                for(var i=0;i

                        data.data[i].value = data.data[i].companyName;   

                }

                cb(data.data);

      });

}

 我需要筛选的数据字段名并不是value,所以现在需要遍历数组把筛选字段换成value

最后将数据 cb() 回去  返回到 autocomplete 组件中 

Element UI 中的 el-autocomplete 是一个自动完成输入框组件,可以帮助用户输入并从预设的选项中选择。 要使用 el-autocomplete 组件,首先需要引入 Element UI 的样式和 JavaScript 文件。然后在您的 Vue 组件中使用 el-autocomplete 组件即可。 以下是一个简单的示例代码,展示如何使用 Element UIel-autocomplete 组件: ```html <template> <div> <el-autocomplete v-model="selectedValue" :fetch-suggestions="querySearch" placeholder="请输入内容" @select="handleSelect" ></el-autocomplete> </div> </template> <script> export default { data() { return { selectedValue: '', options: ['选项1', '选项2', '选项3', '选项4'] }; }, methods: { querySearch(queryString, cb) { const results = queryString ? this.options.filter(option => option.includes(queryString)) : this.options; // 模拟异步请求,可以根据实际情况进行调整 setTimeout(() => { cb(results); }, 200); }, handleSelect(value) { console.log('Selected value:', value); } } }; </script> ``` 在上面的代码中,我们通过 `v-model` 指令将用户选择的值绑定到 `selectedValue` 变量上。通过 `fetch-suggestions` 属性指定一个函数来获取匹配的选项列表,这里我们使用 `querySearch` 方法来实现自定义的搜索逻辑。`placeholder` 属性用于设置输入框的提示文本。通过 `@select` 事件监听选择事件,并在 `handleSelect` 方法中处理选择事件。 以上是一个基本的使用示例,您可以根据自己的需求进行定制和扩展。希望能对您有所帮助!如果您还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值