博客的前某一篇文章中http://www.jb51.net/article/35175.htm写过一个用Ajax来实现一个文本框输入的提示功能。最近在一个管理项目的项目中,使用后发现,真的反应很慢,数据量很大的情况下使用Ajax去实现真的不合适,于是,我又写了一个使用Jquery来实现方法。

废话不多说,上图上代码:

引用方式:

按项目名称检索:

JS代码:

//实现搜索输入框的输入提示js类

var oSearchSuggest = function(searchFuc) {

// function oSearchSuggest(searchFuc) {

var searchsubmit = $('#btnSearchProject');

var input = $('#search');

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 < 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('mousedown', function() {

input.val(this.innerHTML);

suggestWrap.hide();

searchsubmit.click();

});

}

init();

};

//实例化输入提示的JS,参数为进行查询操作时要调用的函数名

var searchSuggest = new oSearchSuggest(sendKeyWordToBack);

//这是一个模似函数,实现向后台发送ajax查询请求,并返回一个查询结果数据,传递给前台的JS,再由前台JS来展示数据。本函数由程序员进行修改实现查询的请求

//参数为一个字符串,是搜索输入框中当前的内容

function sendKeyWordToBack(keyword) {

var sSearchKey = $("#search").val();

$("#search").bind("input propertychange", function(event) {

sSearchKey = $("#search").val();

});

$.ajax({

url: "WebService/wbsBLL.asmx/GetSearchInfo", //后台webservice里的方法名称根据自己需要实现返回数据位json

type: "POST",

dataType: "json",

async: false,

contentType: "application/json; charset=utf-8",

data: '{"sKeyName":"' + sSearchKey + '"}',

traditional: false,

beforeSend: function(x) { x.setRequestHeader("Content-Type", "application/json; charset=utf-8"); },

success: function(data) {

var aData = [];

for (var i in data) {

var jsonObj = $.parseJSON(data[i]);

for (var item in jsonObj) {

jsonObj = eval(jsonObj.SeachTable);

for (var i = 0; i < jsonObj.length; i++) {

if (jsonObj[i].projectName != "") {

aData.push(jsonObj[i].projectName);

}

}

}

}

searchSuggest.dataDisplay(aData);

},

error: function(msg, e) {

$("#filter_stationType").html("SQL语句有错误");

},

complete: function(x) {

}

});

}

index.css:

@charset "utf-8";

/* CSS Document */

body, ul, li {

margin: 0;

padding: 0;

}

body{

font-size:12px;

font-family:sumsun,arial;

color:#666666;

background:#FFFFFF;

}

#searchtable{background:#E4E9F2; border-bottom:1px solid #C8CFDA; padding:0px 8px;height: 33px;}

#searchtable label{font-size:14px; display:inline-block; float:left; color:#333; text-shadow:1px 1px 0px #EBF5FA; font-weight:bold; padding:10px 0 8px 16px; background:url(../images/pemIcons.png) 2px -34px no-repeat; _background:url(../images/pemIcons.gif) 2px -34px no-repeat;}

#searchtable #search{border: 1px solid #C3C3C3; border-top: 1px solid #7C7C7C; border-left: 1px solid #9A9A9A;background: url(../images/today.gif) 0 -162px white repeat-x;outline: none; padding:3px 4px; _padding:3px 4px 5px; display:inline-block; float:left; margin:6px 12px 4px 0; zoom:1;}

#searchtable .btnSubmit{margin-top:6px;margin-left:5px; zoom:1; border: 1px solid #236300; background: #6B9F40 url(../images/buttonbg01.png) repeat-x 0 0; font-size:12px; color:#FFF; line-height:24px; height:24px; width:60px; font-weight:bold; display:block; text-align:center; float:left;}

#searchtable .btnSubmit:hover{text-decoration:none; background-position:0 -32px;}

#searchtable .btnSubmit:active{background-position:0 -64px;}

#searchtable .fBtn:hover{color:#000;}

table.datagrid {

border:1px solid #DDDDDD;

border-collapse:collapse;

}

.gover_search{ position:relative; z-index:99; height:33px; padding:15px 0 0 20px; border:1px solid #b8cfe6; border-bottom:0; background:#E4E9F2;border-bottom:1px solid #C8CFDA;}

.gover_search_form{height:36px;}

.gover_search .search_t{ float:left; width:112px; line-height:26px; color:#666666;}

.gover_search .input_search_key{ float:left; width:462px; height:18px; padding:3px; margin-right:5px; border:1px solid #cccccc; line-height:18px; background:#FFFFFF;}

.gover_search .search_btn{ padding-left:4px; width:68px; height:26px; overflow:hidden; border:1px solid #cccccc; text-align:center; color:#ffffff; letter-spacing:5px; background: #6B9F40 url(../images/buttonbg01.png) repeat-x 0 0; cursor:pointer; font-weight:bold;}

.gover_search .search_suggest{ position:absolute; z-index:999; left:132px; top:41px; width:468px; border:1px solid #999999; display:none; }

.gover_search .search_suggest li{height:24px; overflow:hidden; padding-left:3px; line-height:24px; background:#FFFFFF; cursor:default;}

.gover_search .search_suggest li.hover{background:#DDDDDD;}

后台的webservice代码这里就不展示了,主要就是查询数据库返回一个JSON格式的查询结果给Jquery中的Data

ajax实现搜索提示源码,Jquery实现搜索框提示功能示例代码相关推荐

  1. 娃娃机微信php源码,jQuery手机微信夹娃娃机游戏代码

    jQuery手机微信夹娃娃机游戏代码 js代码 window.οnlοad=function(){ var k=0;//可以点击 var c=0;//娃娃的 scrollLeft();//娃娃滚动 v ...

  2. 锦标赛算法c语言,多目标遗传算法 ------ NSGA-II (部分源码解析) 交叉操作 crossover.c(示例代码)...

    遗传算法中的交叉操作是 对NSGA-II  源码分析的  最后一部分, 这一部分也是我 从读该算法源代码和看该算法论文理解偏差最大的  函数模块. 这里,首先提一下,遗传算法的  交叉操作.变异操作都 ...

  3. linux memcache 源码包,Linux 安装Memcache扩展支持(示例代码)

    查看相关软件包 yum search memcached 安装memcache yum -y install memcachedMemcache关联php yum -y install php-pec ...

  4. 带后台管理的超酷jquery+ajax幻灯相册php源码,仿门户网图片频道的jQuery幻灯相册轮播代码...

    推荐 jquery画廊特效 支持缩略图预览和全屏展示及图片描述 这是款基于jquery的画廊相册特效,功能较全面,可支持缩略小图预览,幻灯图片全屏展示,可显示多种规格的图片,包括全屏显示高清大图,以及 ...

  5. 计算机毕业设计Java社交物联网的服务搜索系统(源码+系统+mysql数据库+lw文档)

    计算机毕业设计Java社交物联网的服务搜索系统(源码+系统+mysql数据库+lw文档) 计算机毕业设计Java社交物联网的服务搜索系统(源码+系统+mysql数据库+lw文档) 本源码技术栈: 项目 ...

  6. 游戏陪玩网站源码开发,搜索功能的实现与页面倒计时跳转

    在游戏陪玩网站源码开发时,首页会有一个搜索输入框和按钮区域,我们要做的就是来完善这部分功能.首先游戏陪玩网站源码搜索的逻辑,我们简单地设定为问题的title或者content包含搜索的关键字即可.假设 ...

  7. 【Android 逆向】ART 脱壳 ( dex2oat 脱壳 | aosp 中搜索 dex2oat 源码 | dex2oat.cc#main 主函数源码 )

    文章目录 前言 一.搜索 dex2oat 源码 二.dex2oat.cc#main 主函数源码 前言 在 [Android 逆向]ART 脱壳 ( DexClassLoader 脱壳 | exec_u ...

  8. 抖音SEO优化源码,企业号搜索排名系统,矩阵同步分发。

    前言:抖音SEO优化源码,企业号搜索排名系统,矩阵同步分发. 抖音seo源码如何搭建?抖音seo排名优化系统软件部分源码分析,代码打包中... 场景:在 python 中,你可以使用 list[10: ...

  9. 抖音SEO优化源码,企业号搜索排名系统,矩阵分发。

    前言:抖音SEO优化源码,企业号搜索排名系统,矩阵分发. 场景:在 python 中,你可以使用 list[10:20:3] 来获取 10 到 20 索性中每隔 3 个的元素组成的数组(也支持负数索引 ...

最新文章

  1. css实现提示信息,单纯使用CSS实现动态提示信息
  2. EMNLP 2020 | 通过Contrast Set评估模型的局部决策边界
  3. 2小时撸完代码之后,所有程序员都逃不过的一天... (强共鸣)
  4. 说给做管理软件的同行:你们得学会职业规划
  5. Activiti源码 之工厂模式
  6. Linux-----diff命令
  7. 实现textarea限制输入字数
  8. MySQL中的前缀索引
  9. GDAL读取S-57海图数据中文属性值乱码问题解决(续)
  10. 拓端tecdat|R语言混合图形模型MGM的网络可预测性分析
  11. Qt编写安防视频监控系统23-图片地图
  12. LTE中的CQI RI PMI参数
  13. 个人java学习路线-Spring
  14. android 百度绑定身份证
  15. 地图比例尺学习、超图最小可见比例尺和最大可见比例尺
  16. java报表是什么_什么是报表工具
  17. 【大数据面试题】(五)Spark 相关面试题总结
  18. VM安装win7系统一直失败,可能是镜像文件不对
  19. shp文件中polyline是什么_polyline怎么读用法大全_polyline是什么意思
  20. 扩展欧几里得算法 | exgcd 证明 + 板子 + 习题

热门文章

  1. 查看电脑最近使用文件记录
  2. FRM-40106:No navigable items in destination block.
  3. 四季酒店升级应用程序,加入行程规划功能
  4. Swift 图片添加文字水印
  5. 操作系统之上下文切换
  6. Win10操作系统切换到管理员身份具体操作方法
  7. JAVA——实现循环录入学员Java课程的成绩(学员数量由键盘录入),统计分数大于等于80分的学生的比例。
  8. java font.createfont_Java Workbook.createFont方法代码示例
  9. html space空格符
  10. 内网访问外网以及外网访问内网的原理