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

效果图:

代码实例如下:

搜索框关键字智能匹配实例代码

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.gif) 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.gif) 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('blur',function(){setTimeout(hideSuggest,100);})

}

var hideSuggest = function(){

suggestWrap.hide();

}

//发送请求,根据关键字到后台查询

var sendKeyWord = function(event){

//键盘选择下拉项

if(suggestWrap.css('display')=='block'&&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

{

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+'2012是真的');

aData.push('约100个'+keyword+'2012是假的');

aData.push('约100个'+keyword+'2012是真的');

aData.push('约100个'+keyword+'2012是假的');

//将返回的数据传递给实现搜索输入框的输入提示js类

searchSuggest.dataDisplay(aData);

}

更多关于搜索功能的文章请查看专题《JavaScript搜索功能汇总》

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

智能搜索框html代码,js实现搜索框关键字智能匹配代码相关推荐

  1. html中搜索框提示语,JS实现搜索关键词的智能提示功能

    最近在百度搜索的时候,当你输入一个字或者词的时候,他会给你们弹出一个下拉框出来,里面是和你相关的搜索提示 比如 我输入杨字,他会给我提示以下搜索提示 我尝试着用JavaScript做了一个类似的练习, ...

  2. html js文本框文字列出,js实现文本框中输入文字页面中div层同步获取文本框内容的方法...

    这篇文章主要介绍了js实现文本框中输入文字页面中div层同步获取文本框内容的方法,实例分析了javascript操作dom元素的技巧,需要的朋友可以参考下 本文实例讲述了js实现文本框中输入文字页面中 ...

  3. html文本框自动赋值,js给文本框赋值 value与innerHTML

    赋值操作: document.getElementById("testId").value="hello"; value与innerHTML的区别 上面的val ...

  4. php和js搜索框,利用PHP+JS实现搜索自动提示(实例)_php技巧

    我觉得我有必要写这个教程,因为曾经见到的大部分关于自动完成的应用程序都只是给你一个程序源码包,然后告诉你怎么使用,而不是告诉你它是如何工作的以及为什么这样做.而知道这些可以让你对这个插件可以进一步的按 ...

  5. php文本框限制字节,js限制文本框输入长度两种限制方式(长度、字节数)_基础知识...

    功能/特点: 1.实时显示可输入的字数(字节数) 2.两种限制方式(长度.字节数) 3.中文输入法下可正常使用,无BUG 4.同一页面可以使用多个,相互不干扰 limit.js function li ...

  6. HTML中拖动消失的球代码,js拖拽360桌面悬浮球代码

    原生js制作简单好用的360桌面悬浮球,可拖拽到浏览器边缘,自动贴边,自动适应屏幕效果. 使用方法: 1.head引入css文件 * { margin: 0; padding: 0; list-sty ...

  7. 图片随机出现的HTML代码,JS随机显示网页图片的简单代码

    如果你想在网页中显示几张图片中的任何一张,即随机显示图片,那么,可以使用如下很简单的代码. 前提条件为:图片均为gif格式的,存放在网站的Img/Gif/JSpc/目录中. 代码如下: var m=9 ...

  8. 数据库关键字搜索查询html,js实现搜索框关键字智能匹配代码

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

  9. 使用jsonp跨域调用百度js实现搜索框智能提示,并实现鼠标和键盘对弹出框里候选词的操作【附源码和在线测试地址】

    项目中常常用到搜索,特别是导航类的网站.自己做关键字搜索不太现实,直接调用百度的是最好的选择. 使用jquery.ajax的jsonp方法可以异域调用到百度的js并拿到返回值,当然$.getScrip ...

最新文章

  1. brave浏览器_兼容Chrome 插件的Brave浏览器,带给你更快速的上网冲浪体验
  2. Notepad++免费开源文本编辑器
  3. PDU知识全集,值得收藏!
  4. window环境中Jupyter notebook使用虚拟环境
  5. Web.config详解
  6. 【Ubuntu】通过虚拟机安装系统( ubuntu )
  7. 建立表/索引时的 存储参数:【PCTUSED参数与PCTFREE参数】
  8. 3D环动画css3实现,CSS3 3D酷炫立方体变换动画的实现
  9. 检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败
  10. node html5,html5前端入门教程分享:Node.Js 框架
  11. _DataStructure_C_Impl:稀疏矩阵三元组
  12. sae php api,api.php · silenceper/saeApi - Gitee.com
  13. WIN7下访问ftp的方法
  14. Linux进不了进程,既然在Linux中程序不是进程,那么到底什么才算是进程呢?
  15. 熊猫烧香病毒样本分析
  16. Android源码下载
  17. 百度排名规则及算法(百度内部资料)
  18. 无线测温采集设备及无线测温监控系统的选型指导-安科瑞王婧
  19. R语言常微分方程数值解海强作业
  20. 二叉树——根据 中序 和 层序 建树,超详讲解。

热门文章

  1. 使用Freemarker的宏和模板生成html打印
  2. python将矩阵存为lmdb文件
  3. 现在的年轻人怎么了?
  4. 【数据结构】迷宫问题实现(包含界面)
  5. 【uni-app项目】瑞幸咖啡小程序
  6. 显示屏播放服务器S3的前身,道可视S3+高端音乐车机略胜一筹
  7. HTML5详细学习资料
  8. 如何用python做二维码识别软件_Python什么都能做(一)用 Python 做一个扫码工具...
  9. C#WEB项目中使用WebBrowser组件
  10. 数据地图、血缘分析与数据资产 详解