欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Jquery實現(xiàn)搜索框提示功能示例代碼

 更新時間:2013年08月13日 16:12:00   作者:  
數(shù)據(jù)量很大的情況下使用Ajax去實現(xiàn)真的不合適,于是想采用Jquery來實現(xiàn)方法,具體的示例代碼如下,有需求的朋友可以參考下希望對大家有所幫助
博客的前某一篇文章中http://www.dbjr.com.cn/article/35175.htm寫過一個用Ajax來實現(xiàn)一個文本框輸入的提示功能。最近在一個管理項目的項目中,使用后發(fā)現(xiàn),真的反應(yīng)很慢,數(shù)據(jù)量很大的情況下使用Ajax去實現(xiàn)真的不合適,于是,我又寫了一個使用Jquery來實現(xiàn)方法。
廢話不多說,上圖上代碼:
 
引用方式:
復(fù)制代碼 代碼如下:

<body style="background-color: White;">
<form id="form1" runat="server">
<div id="filter_stationType"></div>
<div class="gover_search" width="100%">
<div class="gover_search_form clearfix" width="100%">
<span class="search_t"><b>按項目名稱檢索:</b></span>
        <%--autocomplete="off" 這個設(shè)置是禁止瀏覽器自動完成提示功能(就是歷史記錄自動提示)--%>
<asp:TextBox ID="search" runat="server" CssClass="input_search_key" Width="240px" autocomplete="off"></asp:TextBox> <asp:Button ID="btnSearchProject" runat="server" CssClass="search_btn" Text="查詢" OnClick="btnSearchProject_Click" /> <div class="search_suggest" id="gov_search_suggest"> <ul> </ul> </div> </div> </div> </form> </body>

JS代碼:
復(fù)制代碼 代碼如下:

<script type="text/javascript">
//實現(xiàn)搜索輸入框的輸入提示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();
}
//發(fā)送請求,根據(jù)關(guān)鍵字到后臺查詢
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;
}
}
//請求返回后,執(zhí)行數(shù)據(jù)展示
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();
//為下拉選項綁定鼠標(biāo)事件,實現(xiàn)鼠標(biāo)點擊選取
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,參數(shù)為進行查詢操作時要調(diào)用的函數(shù)名
var searchSuggest = new oSearchSuggest(sendKeyWordToBack);
//這是一個模似函數(shù),實現(xiàn)向后臺發(fā)送ajax查詢請求,并返回一個查詢結(jié)果數(shù)據(jù),傳遞給前臺的JS,再由前臺JS來展示數(shù)據(jù)。本函數(shù)由程序員進行修改實現(xiàn)查詢的請求
//參數(shù)為一個字符串,是搜索輸入框中當(dāng)前的內(nèi)容
function sendKeyWordToBack(keyword) {
var sSearchKey = $("#search").val();
$("#search").bind("input propertychange", function(event) {
sSearchKey = $("#search").val();
});
$.ajax({
url: "WebService/wbsBLL.asmx/GetSearchInfo", //后臺webservice里的方法名稱根據(jù)自己需要實現(xiàn)返回數(shù)據(jù)位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) {
}
});
}
</script>

index.css:
復(fù)制代碼 代碼如下:

@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代碼這里就不展示了,主要就是查詢數(shù)據(jù)庫返回一個JSON格式的查詢結(jié)果給Jquery中的Data

相關(guān)文章

  • jQuery 文本框模擬下拉列表效果

    jQuery 文本框模擬下拉列表效果

    學(xué)校作業(yè)的問題,就在網(wǎng)搜了一下,找不到文本框模擬的(可能本人RP問題),看到的都是用div的,結(jié)果就自己弄了一個,主要就是改變背景圖片的位置,讓div的位置放到文本框上面,沒什么其它的東西,呵呵,見笑了
    2010-02-02
  • 基于jQuery實現(xiàn)表單提交驗證

    基于jQuery實現(xiàn)表單提交驗證

    本文給大家分享的是一段基于jQuery的實現(xiàn)簡單的表單提交驗證的代碼,非常簡單實用,推薦給有相同需求的小伙伴們參考下。
    2014-11-11
  • jQuery插件imgPreviewQs實現(xiàn)上傳圖片預(yù)覽

    jQuery插件imgPreviewQs實現(xiàn)上傳圖片預(yù)覽

    這篇文章主要介紹了jQuery插件imgPreviewQs實現(xiàn)上傳圖片預(yù)覽的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Javascript中的異步編程規(guī)范Promises/A詳細(xì)介紹

    Javascript中的異步編程規(guī)范Promises/A詳細(xì)介紹

    這篇文章主要介紹了Javascript中的異步編程規(guī)范Promises/A詳細(xì)介紹,同時介紹了jQuery 中的 Deferred 和 Promises,需要的朋友可以參考下
    2014-06-06
  • jQuery插件animateSlide制作多點滑動幻燈片

    jQuery插件animateSlide制作多點滑動幻燈片

    本文給大家分享的是使用jQuery插件animateSlide制作多點滑動幻燈片特效,十分的炫酷,有需要的小伙伴可以參考下
    2015-06-06
  • niceTitle 基于jquery的超鏈接提示插件

    niceTitle 基于jquery的超鏈接提示插件

    niceTitle是一款當(dāng)鼠標(biāo)移到超鏈接上面顯示提示的插件。我們可以使用該插件來實現(xiàn)新聞、文字的預(yù)覽。
    2010-05-05
  • jQuery中wrapInner()方法用法實例

    jQuery中wrapInner()方法用法實例

    這篇文章主要介紹了jQuery中wrapInner()方法用法,實例分析了wrapInner()方法的功能、定義及包裹匹配元素的使用技巧,需要的朋友可以參考下
    2015-01-01
  • jQuery簡單實現(xiàn)遍歷單選框的方法

    jQuery簡單實現(xiàn)遍歷單選框的方法

    這篇文章主要介紹了jQuery簡單實現(xiàn)遍歷單選框的方法,涉及jQuery針對頁面表單元素的遍歷及事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03
  • 基于jquery實現(xiàn)頁面滾動時頂部導(dǎo)航顯示隱藏

    基于jquery實現(xiàn)頁面滾動時頂部導(dǎo)航顯示隱藏

    這篇文章主要介紹了基于jquery實現(xiàn)頁面滾動時頂部導(dǎo)航顯示隱藏效果,當(dāng)頁面向下滾動的時候,導(dǎo)航菜單動態(tài)隱藏,頁面滾動到頂部時,導(dǎo)航菜單動態(tài)顯示,淘寶也采用過此效果,感興趣的小伙伴們可以參考一下
    2015-11-11
  • 動態(tài)設(shè)置form表單的action屬性的值的簡單方法

    動態(tài)設(shè)置form表單的action屬性的值的簡單方法

    下面小編就為大家?guī)硪黄獎討B(tài)設(shè)置form表單的action屬性的值的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05

最新評論