JavaScript实现前端实时搜索功能

大部分页面都具备搜索功能。而作为前端,我们的目的只是将用户输入的内容返回给后台而后呈现反馈数据给用户,具体实现如下:

1.基本布局:

rush:xhtml;">
名称">

这里涉及一个问题如何将搜索图标放入input中,网上有相关资料不做赘述:

rush:css;"> .searcher { background: rgba(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专属的。

rush:js;"> //监听input框,实时渲染 $('.searcher-text').on('input',function() { initSearchList(); });

JQ一般都是用这种+=html的方法,虽然累赘不过通过url或者tag标签属性传参较容易理解。

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 + ''
});
$('.searcher-list').html(html);
}
//无结果
else {
html = '<div class="no-goods">暂时无法找到此选项~
';
$('.searcher-list').html(html);
}
});
}

注意这里有一个replaceIllegalstr()方法,类似正则,目的是过滤掉一些无用的符号以免给后端接收数据带来不必要的麻烦。

rush:js;"> 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是自己封装的一个方法属性的对象

rush:js;"> //设置缓存 epm.setLocalItem = function(key,value) { if (window.localStorage) { localStorage.setItem(key,value); } else { //后备方案 setCookie(key,value); } };
rush:js;"> //提取缓存 epm.getLocalItem = function(key) { if (window.localStorage) { return localStorage.getItem(key); } else { //后备方案 return getCookie(key); } };
rush:js;"> //删除缓存 epm.removeLocalItem = function(key) { if (window.localStorage) { localStorage.removeItem(key); } else { //后备方案 removeCookie(key); } };

这里写图片描述

6.step-3

得到点击的相应的缓存词里的value,再次发送ajax:

内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...