前段时间,在实现带输入建议并且支持模糊查询输入框的时候,发现了两个值得注意的小地方。整理出来,以供借鉴。
废话不多说,直接来解决问题。
踩坑问题描述:
问题一:
获取到后端返回的数组,并将数组传入作为 results
传入 callback
后,焦点放在 输入框
上的时候,并未出现任何内容,只出现了一个不完整的空白框。
问题解决方案:
这个问题开始我以为是传进 callback
的 data
格式不对。Element官网上是这么写的:
我传入的是对象数组,是没问题的。
后来我仔细阅读了 Elemen t带建议查询输入框的 Demo 代码并查阅相关资料发现,输入建议列表的数据只来源于
data:[]
中的 value
字段!!!
于是,我将后端传回的 response
处理了,将 response
中需要展示的字段组成 {value:'输入建议'}
这种格式,问题解决。
searchAppNodeApi(searchQuery).then((response) => { this.loadAll = response.data this.devEuiArr = []; for (var i = 0; i < this.loadAll.length; i++) { this.devEuiArr.push({"value1": this.loadAll[i].dev_eui}) } })
searchAppNodeApi()
是我请求后端的api方法,拿到请求成功的回调函数的 response
参数。但是, response
里面包含很多我不需要的字段,我只需要其中的 dev_eui
字段。因此,循环 response.data
将其中每条的 dev_eui
重组成 {value:'输入建议'}
的格式并 push 进声明的新数组 devEuiArr
。
打印如下:
正确效果如下:
问题二:
成功出现输入建议列表后,出现一个新的问题,并且 Element 官网的 Demo 代码并未阐述这种情况,就是当我获取到输入建议列表后,切换成另一个输入建议列表,会先闪一下上一个出现的输入建议列表,切换后的输入列表为空也会闪出上个输入建议列表,就算手动清空 callback(data:[])
中的 data
数组也无济于事。
问题解决方案:
这个问题开始我以为是需要返回数据后手动清空 callback
里面的 data
数组,像下面这样:
//联想查询时触发 querySearch(queryString, callback) { var results = queryString "text-align: center">
debounce
?函数去抖
"htmlcode"><el-autocomplete placeholder="请输入DEVEUI" v-model="searchDeveuiVal" clearable :fetch-suggestions="querySearch" size="small" :debounce=0 @keyup.enter.native="searchAppNode"> </el-autocomplete>正确效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]