网站优化

个人怎么做微信小程序_jQuery完成模糊查询的方法

作者:admin 发布时间:2021-01-08
jQuery实现模糊查询的方法分析       这篇文章主要介绍了jQuery实现模糊查询的方法,结合实例形式分析了jQuery事件响应、节点遍历、查询匹配、属性修改等相关操作技巧,需要的朋友可以参考下

本文实例讲述了jQuery实现模糊查询的方法。分享给大家供大家参考,具体如下:

需求:list列表内容很多,用户需要找出列表内容中的某些条目,只有当与用户输入值匹配的条目才显示出来。(后台无分页,直接异步接口返回数据添加形成的内容列表)

虽然可以通过传参再调用查询出来,但这里主要记录的是前端处理进行模糊查询而无需再次调用接口的实现方法。

html部分:

 div 
 input type="text" placeholder="请输入关键词" 
 span /span 
 /div 
 div 
 div 
 div 列表一 /div 
 div 列表二 /div 
 div 列表三 /div 
 div 列表四 /div 
 div 列表五 /div 
 /div 
 div 
 div 00001 /div 
 div 内容1 /div 
 div 内容2 /div 
 div 内容3 /div 
 div 内容4 /div 
 /li 
 li …… /li 
 /ul 
 /div 
 /div 

js部分:

queryList: function(){
 $(".search-input").on("input propertychange", function() {
 var queryStr = $.trim($(".search-input").val());
 if(queryStr === ''){
 $(".list-content li").show();
 }else{
 // 以下是匹配某些列的内容,如果是匹配全部列的话就把find()和.parent()去掉即可
 $(".list-content li").hide().find(".code, .name").filter(":contains('"+queryStr+"')").parent("li").show();
 //$(".list-content").refresh(); //重新刷新列表把隐藏的dom结构去掉。

分析:以上即实现了前端js的模糊查询功能啦,哈哈。代码中监听事件中多加了input,据说是为兼容iOS的,具体没测试,有哪位大神测试了可以告知一声哈,谢谢了。

还有个问题就是,以上实现方法,当列表内容多大几千条数目或者更多时,表单输入时会出现卡顿的情况,因为要通过js操作大量的DOM结构啊(隐藏或显示),PC上或许情况还没有那么严重,在手机上测试时那真的是“怎一个卡字了得”,如果哪位大神有更好的法子,还望加以完善!

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》及《》

希望本文所述对大家jQuery程序设计有所帮助。



收缩