JavaScript实现前端实时搜索功能
程序员文章站
2023-10-30 15:32:22
大部分页面都具备搜索功能。而作为前端,我们的目的只是将用户输入的内容返回给后台而后呈现反馈数据给用户,具体实现如下:
1.基本布局:
大部分页面都具备搜索功能。而作为前端,我们的目的只是将用户输入的内容返回给后台而后呈现反馈数据给用户,具体实现如下:
1.基本布局:
<div class="searcher"> <p class="searcher-main"> <i><img src="img/icon/icon-search-map.png"/></i> <input class="searcher-text" placeholder="请输入档口名称"></input> </p> <p class="searcher-cancel">取消</p> </div>
这里涉及一个问题如何将搜索图标放入input中,网上有相关资料不做赘述:
.searcher { background: rgba(255, 255, 255, 0); position: fixed; z-index: 999; width: 100%; height: 6rem; text-align: center; font-size: 1.6rem; } .searcher-main { background: #f4f4f4; position: absolute; left: 50%; top: 1.2rem; margin-left: -45%; border-radius: 1.6rem; width: 80%; height: 3rem; line-height: 3rem; } .searcher-text { width: 80%; text-align: center; border: none; outline: none; background: #f4f4f4; } .searcher-cancel { position: absolute; width: 10%; height: 3rem; line-height: 3rem; color: #929292; top: 1.2rem; right: 1rem; }
2.step-1:
3.js部分
这里要安利ie9以上的oninput事件
onchange事件只在键盘或者鼠标操作改变对象属性,且失去焦点时触发,脚本触发无效。
onkeydown/onkeypress/onkeyup在处理复制、粘贴、拖拽、长按键(按住键盘不放)等细节上并不完善。
onpropertychange不用考虑是否失去焦点,不管js操作还是键盘鼠标手动操作,只要html元素属性发生改变即可立即捕获到。遗憾的是,onpropertychange为ie专属的。
//监听input框,实时渲染 $('.searcher-text').on('input', function() { initsearchlist(); });
jq一般都是用这种+=html的方法,虽然累赘不过通过url或者tag标签里属性传参较容易理解。
//渲染搜索列表 function initsearchlist() { var list = $('.searcher-land ul'); var params = {}; //搜索过滤字符 var search_key = $('.searcher-text').val() params['action'] = 'get_search_key_list'; params['market_iid'] = 1001; params['search_type'] = type; params['search_key'] = replaceillegalstr(search_key); epm.ajax(params, function(result) { console.log(result); console.log(type) var html = ''; list.html(''); //有结果 if(result.data.length > 0) { $.each(result.data, function(index, value) { goodname = value['goods_name']; shopname = value['shop_name']; //判断name类型 itemname = (goodname) ? goodname : shopname; html += '<li class="goods-list">' + itemname + '</li>' }); $('.searcher-list').html(html); } //无结果 else { html = '<div class="no-goods">暂时无法找到此选项~</div>'; $('.searcher-list').html(html); } }); }
注意这里有一个replaceillegalstr()方法,类似正则,目的是过滤掉一些无用的符号以免给后端接收数据带来不必要的麻烦。
function replaceillegalstr(str) { var reg; var illegal_list = ["/", "\\", "[", "]", "{", "}", "<", ">", "<", ">", "「", "」", ":", ";", "、", "•", "^", "'", "\"", "\r", "\r\n", "\\n", "\n"]; for (var i = 0; i < illegal_list.length; i++) { if (str.indexof(illegal_list[i]) >= 0) { if (illegal_list[i] == '\\' || illegal_list[i] == '[') { reg = new regexp('\\' + illegal_list[i], "g"); } else { reg = new regexp(illegal_list[i], "g"); } str = str.replace(reg, ''); } } return str.trim(); }
4.step-2:
5.缓存
这里我们将点击的数据保存在本地缓存里,供取用呈现:
注: epm是自己封装的一个方法与属性的对象
//设置缓存 epm.setlocalitem = function(key, value) { if (window.localstorage) { localstorage.setitem(key, value); } else { //后备方案 setcookie(key, value); } };
//提取缓存 epm.getlocalitem = function(key) { if (window.localstorage) { return localstorage.getitem(key); } else { //后备方案 return getcookie(key); } };
//删除缓存 epm.removelocalitem = function(key) { if (window.localstorage) { localstorage.removeitem(key); } else { //后备方案 removecookie(key); } };
6.step-3
得到点击的相应的缓存词里的value,再次发送ajax:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
android实现搜索功能并将搜索结果保存到SQLite中(实例代码)
-
javascript实现的图片预览和上传功能示例【兼容IE 9】
-
CSS JavaScript 实现菜单功能 改进版
-
jQuery实现条件搜索查询、实时取值及升降序排序的方法分析
-
PHP实现绘制二叉树图形显示功能详解【包括二叉搜索树、平衡树及红黑树】
-
JavaScript实现的前端AES加密解密功能【基于CryptoJS】
-
JavaScript基于replace+正则实现ES6的字符串模版功能
-
用JavaScript实现页面重定向功能的教程
-
使用ElasticSearch6.0快速实现全文搜索功能的示例代码
-
JavaScript实现定时页面跳转功能示例