200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > js实现搜索框关键字智能匹配代码【javascript】

js实现搜索框关键字智能匹配代码【javascript】

时间:2020-10-10 11:59:51

相关推荐

js实现搜索框关键字智能匹配代码【javascript】

web前端|js教程

js,搜索框,关键字,智能匹配

web前端-js教程

只要使用搜索引擎的朋友应该都有这样的体会,就是当在搜索框输入关键字的时候,会出现自能匹配现象,这绝对是非常好的用户体验,下面就是一段类似的代码,当然这里只是掩饰,所以只能匹配的数据都是本地固定好的,在实际应用中可以才能够数据库读取数据。

老虎机安卓源码,ubuntu显卡驱动型号,反跟踪爬虫技术,armbian php,余庆seo优化lzw

效果图:

vb 获取源码,ubuntu 完全卸载包,tomcat 支持用户数,python 爬虫教学,php首页广告弹窗代码,janguk seolzw

mfc程序源码,vscode怎么运行c的命令,ubuntu 分区详解,tomcat日志切割在哪,sqlite 排序 显示,速卖通网页设计过程,服务器怎么做空间,手机端抛物线加入购物车插件,前端组件和框架,文书网爬虫,互刷php,seo实战培训haiyaoseo,springboot修改记录,如何下载网站的源码,java网页客服,图片类网站模板,网站后台管理系统展望,网页注册页面方框的大小,软件项目管理系统 php,e语言程序图标lzw

代码实例如下:

搜索框关键字智能匹配实例代码body, ul, li { margin:0; padding:0;}body { font-size:12px; font-family:sumsun, arial; background:#FFFFFF;}.gover_search { position:relative; z-index:99; height:63px; padding:15px 0 0 20px; border:1px solid #b8cfe6; border-bottom:0; background:url(../images/gover_search_bg.jpg) repeat-x 0 0;}.gover_search_form {height:36px;}.gover_search .search_t { float:left; width:112px; line-height:26px; color:#666;}.gover_search .input_search_key { float:left; width:462px; height:18px; padding:3px; margin-right:5px; border:1px solid #ccc; line-height:18px; background:#fff;}.gover_search .search_btn { float:left; width:68px; height:26px; overflow:hidden; border:1px solid #ccc; text-align:center; color:#ff3300; letter-spacing:5px; background:url(../images/gover_search_bg.jpg) no-repeat 0 -79px; cursor:pointer; font-weight:bold;}.gover_search .search_suggest { position:absolute; z-index:999; left:132px; top:41px; width:468px; border:1px solid #ccc; border-top:none; display:none; color:#004080;}.gover_search .search_suggest li { height:24px; overflow:hidden; padding-left:3px; line-height:24px; background:#fff; cursor:default;}.gover_search .search_suggest li.hover {background:#ddd;}.num_right { float:right; text-align:right; line-height:24px; padding-right:10px}

关键词匹配搜索

function oSearchSuggest(searchFuc){ var input = $(#gover_search_key); var suggestWrap = $(#gov_search_suggest); var key = ""; var init = function(){ input.bind(keyup,sendKeyWord); input.bind(lur,function(){setTimeout(hideSuggest,100);}) } var hideSuggest = function(){ suggestWrap.hide(); } //发送请求,根据关键字到后台查询 var sendKeyWord = function(event){ //键盘选择下拉项 if(suggestWrap.css(display)==lock&&event.keyCode == 38||event.keyCode == 40) { var current = suggestWrap.find(li.hover); if(event.keyCode == 38) {if(current.length>0) {var prevLi = current.removeClass(hover).prev();if(prevLi.length>0){ prevLi.addClass(hover); input.val(prevLi.html());}} else {var last = suggestWrap.find(li:last);last.addClass(hover);input.val(last.html());} } else if(event.keyCode == 40) {if(current.length>0) {var nextLi = current.removeClass(hover).next();if(nextLi.length>0){ nextLi.addClass(hover); input.val(nextLi.html());}} else {var first = suggestWrap.find(li:first);first.addClass(hover);input.val(first.html());} } //输入字符 } else { var valText = $.trim(input.val()); if(valText ==\||valText==key) {return; } searchFuc(valText); key = valText; } } //请求返回后,执行数据展示 this.dataDisplay = function(data){ if(data.length<=0) { suggestWrap.hide(); return; } //往搜索框下拉建议显示栏中添加条目并显示 var li; var tmpFrag = document.createDocumentFragment(); suggestWrap.find(ul).html(\); for(var i=0; i<data.length; i++) { li = document.createElement(LI); li.innerHTML = data[i]; tmpFrag.appendChild(li); } suggestWrap.find(ul).append(tmpFrag); suggestWrap.show(); //为下拉选项绑定鼠标事件 suggestWrap.find(li).hover(function(){ suggestWrap.find(li).removeClass(hover); $(this).addClass(hover); },function(){ $(this).removeClass(hover); }).bind(click,function(){ $(this).find("span").remove(); input.val(this.innerHTML); suggestWrap.hide(); }); } init(); }; //实例化输入提示的JS,参数为进行查询操作时要调用的函数名 var searchSuggest = new oSearchSuggest(sendKeyWordToBack); //这是一个模似函数,实现向后台发送ajax查询请求,并返回一个查询结果数据,传递给前台的JS,再由前台JS来展示数据。本函数由程序员进行修改实现查询的请求 //参数为一个字符串,是搜索输入框中当前的内容 function sendKeyWordToBack(keyword){ var aData = []; aData.push(约100个+keyword+返回数据1); aData.push(约200个+keyword+返回数据2); aData.push(约100个+keyword+返回数据3); aData.push(约50000个+keyword+返回数据4); aData.push(约1044个+keyword+是真的); aData.push(约100个+keyword+是假的); aData.push(约100个+keyword+是真的); aData.push(约100个+keyword+是假的); //将返回的数据传递给实现搜索输入框的输入提示js类 searchSuggest.dataDisplay(aData); }

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。