element 搜索匹配_Element-UI远程搜索功能详解

本文详细介绍了Element UI的远程搜索功能,通过实例展示了如何利用`fetch-suggestions`属性结合回调函数实现动态搜索建议。文章解释了回调函数的工作原理,并提供了实际工程中的应用示例,包括前端和后端的实现代码,帮助读者理解如何在项目中实现远程搜索功能。
摘要由CSDN通过智能技术生成

官方代码:

v-model="state":fetch-suggestions="querySearchAsync"placeholder="请输入内容"@select="handleSelect"

>

data() {return{

restaurants: [],

state:'',

timeout:null};

},

methods: {

loadAll() {return[

{"value": "三全鲜食(北新泾店)", "address": "长宁区新渔路144号"},

{"value": "Hot honey 首尔炸鸡(仙霞路)", "address": "上海市长宁区淞虹路661号"},

{"value": "新旺角茶餐厅", "address": "上海市普陀区真北路988号创邑金沙谷6号楼113"},

{"value": "泷千家(天山西路店)", "address": "天山西路438号"},

{"value": "胖仙女纸杯蛋糕(上海凌空店)", "address": "上海市长宁区金钟路968号1幢18号楼一层商铺18-101"},

{"value": "贡茶", "address": "上海市长宁区金钟路633号"},

{"value": "豪大大香鸡排超级奶爸", "address": "上海市嘉定区曹安公路曹安路1685号"},

{"value": "茶芝兰(奶茶,手抓饼)", "address": "上海市普陀区同普路1435号"},

{"value": "十二泷町", "address": "上海市北翟路1444弄81号B幢-107"},

{"value": "星移浓缩咖啡", "address": "上海市嘉定区新郁路817号"},

{"value": "阿姨奶茶/豪大大", "address": "嘉定区曹安路1611号"},

{"value": "新麦甜四季甜品炸鸡", "address": "嘉定区曹安公路2383弄55号"},

{"value": "Monica摩托主题咖啡店", "address": "嘉定区江桥镇曹安公路2409号1F,2383弄62号1F"},

{"value": "浮生若茶(凌空soho店)", "address": "上海长宁区金钟路968号9号楼地下一层"},

{"value": "NONO JUICE 鲜榨果汁", "address": "上海市长宁区天山西路119号"},

{"value": "CoCo都可(北新泾店)", "address": "上海市长宁区仙霞西路"},

{"value": "快乐柠檬(神州智慧店)", "address": "上海市长宁区天山西路567号1层R117号店铺"},

{"value": "Merci Paul cafe", "address": "上海市普陀区光复西路丹巴路28弄6号楼819"},

{"value": "猫山王(西郊百联店)", "address": "上海市长宁区仙霞西路88号第一层G05-F01-1-306"},

{"value": "枪会山", "address": "上海市普陀区棕榈路"},

{"value": "纵食", "address": "元丰天山花园(东门) 双流路267号"},

{"value": "钱记", "address": "上海市长宁区天山西路"},

{"value": "壹杯加", "address": "上海市长宁区通协路"},

{"value": "唦哇嘀咖", "address": "上海市长宁区新泾镇金钟路999号2幢(B幢)第01层第1-02A单元"},

{"value": "爱茜茜里(西郊百联)", "address": "长宁区仙霞西路88号1305室"},

{"value": "爱茜茜里(近铁广场)", "address": "上海市普陀区真北路818号近铁城市广场北区地下二楼N-B2-O2-C商铺"},

{"value": "鲜果榨汁(金沙江路和美广店)", "address": "普陀区金沙江路2239号金沙和美广场B1-10-6"},

{"value": "开心丽果(缤谷店)", "address": "上海市长宁区威宁路天山路341号"},

{"value": "超级鸡车(丰庄路店)", "address": "上海市嘉定区丰庄路240号"},

{"value": "妙生活果园(北新泾店)", "address": "长宁区新渔路144号"},

{"value": "香宜度麻辣香锅", "address": "长宁区淞虹路148号"},

{"value": "凡仔汉堡(老真北路店)", "address": "上海市普陀区老真北路160号"},

{"value": "港式小铺", "address": "上海市长宁区金钟路968号15楼15-105室"},

{"value": "蜀香源麻辣香锅(剑河路店)", "address": "剑河路443-1"},

{"value": "北京饺子馆", "address": "长宁区北新泾街道天山西路490-1号"},

{"value": "饭典*新简餐(凌空SOHO店)", "address": "上海市长宁区金钟路968号9号楼地下一层9-83室"},

{"value": "焦耳·川式快餐(金钟路店)", "address": "上海市金钟路633号地下一层甲部"},

{"value": "动力鸡车", "address": "长宁区仙霞西路299弄3号101B"},

{"value": "浏阳蒸菜", "address": "天山西路430号"},

{"value": "四海游龙(天山西路店)", "address": "上海市长宁区天山西路"},

{"value": "樱花食堂(凌空店)", "address": "上海市长宁区金钟路968号15楼15-105室"},

{"value": "壹分米客家传统调制米粉(天山店)", "address": "天山西路428号"},

{"value": "福荣祥烧腊(平溪路店)", "address": "上海市长宁区协和路福泉路255弄57-73号"},

{"value": "速记黄焖鸡米饭", "address": "上海市长宁区北新泾街道金钟路180号1层01号摊位"},

{"value": "红辣椒麻辣烫", "address": "上海市长宁区天山西路492号"},

{"value": "(小杨生煎)西郊百联餐厅", "address": "长宁区仙霞西路88号百联2楼"},

{"value": "阳阳麻辣烫", "address": "天山西路389号"},

{"value": "南拳妈妈龙虾盖浇饭", "address": "普陀区金沙江路1699号鑫乐惠美食广场A13"}

];

},

querySearchAsync(queryString, cb) {var restaurants = this.restaurants;var results = queryString ? restaurants.filter(this.createStateFilter(queryString)) : restaurants;

clearTimeout(this.timeout);this.timeout = setTimeout(() =>{

cb(results);

},3000 *Math.random());

},//过滤出state.value中包含queryString的记录

createStateFilter(queryString) {return (state) =>{return (state.value.toLowerCase().indexOf(queryString.toLowerCase()) === 0);

};

},

handleSelect(item) {//console.log(item);

}

},

mounted() {this.restaurants = this.loadAll();

}

};

页面渲染完成后,就模拟从后台获取的数据赋值给this.restaurants。当你点击输入框,此时还没输入数据,queryString为空字符串,results为restaurants,当你输入字符,如“港式”,则queryString就是“港式”,此时queryString不为空,此时results为{ "value": "港式小铺", "address": "上海市长宁区金钟路968号15楼15-105室" }

使用el-autocomplete标签,fetch-suggestions属性:返回输入建议的方法,仅当你的输入建议数据 resolve 时,通过调用 callback(data:[]) 来返回它。

callback 是一种特殊的函数,这个函数被作为参数传给另一个函数去调用。这样的函数就是回调函数。callback 就是传给另一个函数调用的函数

实现的机制

[1]定义一个回调函数;

[2]提供函数实现的一方在初始化的时候,将回调函数的函数指针注册给调用者;

[3]当特定的事件或条件发生的时候,调用者使用函数指针调用回调函数对事件进行处理。

自己的理解:

[1]定义一个回调函数 (cb);

[2]提供函数实现的一方在初始化的时候,将回调函数的函数指针注册给调用者(fetch-suggestions);

[3]当特定的事件或条件发生的时候,调用者(fetch-suggestions)使用函数指针调用回调函数 (cb)对事件进行处理。

实际工程中应用:

//查询搜索处理

querySearch(name, callback) {

if (name != null && name.length > 0) {

//获取搜索数据

medicineListApi.getListByLike({ name }).then(res => {

const list = []

//封装要显示的数据

for (let v of res) {

list.push({ value: v.drugname })

}

// 调用 callback 返回建议列表的数据,是一个数组类型

callback(list)

}, err => {

console.log(err)

})

}

},

在medicineList.js中的代码

//根据名字进行模糊查询,实现搜索提示

getListByLike(params) {

return request.get(baseUrl + "/listByName", { params });

},

后台代码:

controller

@GetMapping("/listByName")

public List getList(@RequestParam String name) {

QueryWrapper wrapper = new QueryWrapper<>();

wrapper.like("drugname",name);

return medicineListService.list(wrapper);

}

service接口:

public interface MedicineListService extends IService{}

service实现类

@Servicepublic class MedicineListServiceImpl extends ServiceImplimplements MedicineListService {

@ResourceprivateMedicineListMapper medicineListMapper;

}

Dao接口

public interface MedicineListMapper extends BaseMapper{

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用的代码是一个Vue项目的配置文件main.js,其中导入了element-ui样式和组件,并且使用了Vue.use(ElementUI)来全局注册了element-ui的所有组件。然后创建了一个Vue实例并挂载到了#app元素上,从而完成了element-ui的配置和使用。 引用是一个关于在el-tree组件中通过render函数生成el-button的示例代码。el-tree是element-ui中的树形组件,通过使用render函数可以自定义树节点的内容和样式。 引用介绍了Element-UI,它是一套基于Vue 2.0的桌面端组件库,提供了一组组件和参考实例。安装ElementUI可以参考官方文档。 根据提供的引用内容,无法确定render函数判断是否的具体上下文和代码。请提供更多相关的信息,以便我能够给出准确的回答。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Element-UI详解](https://blog.csdn.net/qq_42426159/article/details/102928417)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [在element-ui的el-tree组件中用render函数生成el-button的实例代码](https://download.csdn.net/download/weixin_38650516/14824764)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值