asp.net+jquery滾動滾動條加載數(shù)據(jù)的下拉控件
更新時間:2010年06月25日 00:37:33 作者:
由于需求需要用到一個滾動滾動條加載數(shù)據(jù)的下拉列表(假如數(shù)據(jù)1000條,下拉列表開始只顯示100條,當(dāng)用戶下拉滾到條到最底下時,再加載下一個100條,如此循環(huán))
這樣的需求貌似自己感覺不是很合理,因為數(shù)據(jù)多了如此下拉無論從人還是機(jī)器操作都比較痛苦。
沒辦法由于需求下來了,只能按需求操作。網(wǎng)上找了很多相關(guān)控件都感覺有點龐大,占資源比較多。沒辦法自己花半天時間弄出個半成品自定義控件,拿出來分享下,如有高手看了請多指點。
需求:AJAX滾動滾動條加載數(shù)據(jù)的下拉列表
控件名稱:Webcombo
所用技術(shù):ASP.NET(C#),jQuery,ASP.NET一般處理文件(.ashx)
下拉列表具體實現(xiàn):用DIV模擬下拉列表,input和圖片模擬下拉框。最終結(jié)果如下圖

先分析下jQuery這邊的插件寫法吧
AJAX加載有jQuery Ajax完成
$.ajax({
type: options.getMethod,
url: options.jsonUrl,
data: params,
success: function(data){
if(isScroll)
$.CreateListItem(showbox,data,options);
else
$.CreateBox(showbox,data,options);
},
complete:function(){ },
error:function(e){
$(options.loadBox).css('background-image','none');
$(options.loadBox).append('<span>data connect error!'+e+'</span>');
}
而滾動條滾動加載數(shù)據(jù)則由下拉DIV的onscroll事件完成,具體核心代碼如下:
$(showbox).scroll(function(){
if(options.total==$(this).children("ul").children("li").length)
return;
var scrolltop=$(showbox).attr('scrollTop');
var scrollheight=$(showbox).attr('scrollHeight');
var windowheight=$(showbox).attr('clientHeight');
var scrolloffset=20;
$(options.loadBox).css('top',scrolltop);
if(scrolltop>=(scrollheight-(windowheight+scrolloffset))&&!loading)
{
loading=true;
$(options.loadBox).show();
options.total=$(this).children("ul").children("li").length;
$.WebComboGetData(showbox,options,true);
}
});
該插件的完整代碼再源文件中可以找到,文件名:simulateddl.js
其實這個滾動條滾動加載數(shù)據(jù)的jQuery插件寫好了就已經(jīng)可以實現(xiàn)該功能了,只是由于項目中用到的地方比較多又無賴的將其封裝到asp.net自定義控件中。之所以說半成品就是這個自定義控件自定義的有些不人性化,高手們見了望指點指點。具體代碼可以下載后查看,本人不是控件制作高手,就不搬出來獻(xiàn)丑了。有問題建議的朋友可以提出來大家討論討論。
asp.net+jQuery滾動條滾動加載數(shù)據(jù)控件源代碼下載
沒辦法由于需求下來了,只能按需求操作。網(wǎng)上找了很多相關(guān)控件都感覺有點龐大,占資源比較多。沒辦法自己花半天時間弄出個半成品自定義控件,拿出來分享下,如有高手看了請多指點。
需求:AJAX滾動滾動條加載數(shù)據(jù)的下拉列表
控件名稱:Webcombo
所用技術(shù):ASP.NET(C#),jQuery,ASP.NET一般處理文件(.ashx)
下拉列表具體實現(xiàn):用DIV模擬下拉列表,input和圖片模擬下拉框。最終結(jié)果如下圖

先分析下jQuery這邊的插件寫法吧
AJAX加載有jQuery Ajax完成
復(fù)制代碼 代碼如下:
$.ajax({
type: options.getMethod,
url: options.jsonUrl,
data: params,
success: function(data){
if(isScroll)
$.CreateListItem(showbox,data,options);
else
$.CreateBox(showbox,data,options);
},
complete:function(){ },
error:function(e){
$(options.loadBox).css('background-image','none');
$(options.loadBox).append('<span>data connect error!'+e+'</span>');
}
而滾動條滾動加載數(shù)據(jù)則由下拉DIV的onscroll事件完成,具體核心代碼如下:
復(fù)制代碼 代碼如下:
$(showbox).scroll(function(){
if(options.total==$(this).children("ul").children("li").length)
return;
var scrolltop=$(showbox).attr('scrollTop');
var scrollheight=$(showbox).attr('scrollHeight');
var windowheight=$(showbox).attr('clientHeight');
var scrolloffset=20;
$(options.loadBox).css('top',scrolltop);
if(scrolltop>=(scrollheight-(windowheight+scrolloffset))&&!loading)
{
loading=true;
$(options.loadBox).show();
options.total=$(this).children("ul").children("li").length;
$.WebComboGetData(showbox,options,true);
}
});
該插件的完整代碼再源文件中可以找到,文件名:simulateddl.js
其實這個滾動條滾動加載數(shù)據(jù)的jQuery插件寫好了就已經(jīng)可以實現(xiàn)該功能了,只是由于項目中用到的地方比較多又無賴的將其封裝到asp.net自定義控件中。之所以說半成品就是這個自定義控件自定義的有些不人性化,高手們見了望指點指點。具體代碼可以下載后查看,本人不是控件制作高手,就不搬出來獻(xiàn)丑了。有問題建議的朋友可以提出來大家討論討論。
asp.net+jQuery滾動條滾動加載數(shù)據(jù)控件源代碼下載
您可能感興趣的文章:
- jquery實現(xiàn)表格無縫滾動
- Jquery原生態(tài)實現(xiàn)表格header頭隨滾動條滾動而滾動
- jquery滾動組件(vticker.js)實現(xiàn)頁面動態(tài)數(shù)據(jù)的滾動效果
- 基于jquery實現(xiàn)頁面滾動到底自動加載數(shù)據(jù)的功能
- js/jquery控制頁面動態(tài)加載數(shù)據(jù) 滑動滾動條自動加載事件的方法
- jquery滾動加載數(shù)據(jù)的方法
- 使用jQuery或者原生js實現(xiàn)鼠標(biāo)滾動加載頁面新數(shù)據(jù)
- Jquery公告滾動+AJAX后臺得到數(shù)據(jù)
- 拉動滾動條加載數(shù)據(jù)的jquery代碼
- jQuery實現(xiàn)表格行數(shù)據(jù)滾動效果
相關(guān)文章
jQuery使用ajax傳遞json對象到服務(wù)端及contentType的用法示例
這篇文章主要介紹了jQuery使用ajax傳遞json對象到服務(wù)端及contentType的用法,結(jié)合實例形式分析了jQuery使用ajax傳遞json對象數(shù)據(jù)及服務(wù)器響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2020-03-03
ASP.NET jQuery 實例14 在ASP.NET form中校驗時間范圍
這節(jié)主要講如何用jQuery校驗表單時間范圍,時間控件用到了jQuery-ui2012-02-02

