亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 建站經驗 > 正文

分享一個自己動手寫的jQuery分頁插件

2024-04-25 20:31:37
字體:
來源:轉載
供稿:網友

jquery分頁插件的思路和步驟分享給大家,本分頁插件功能很簡單,但是卻很實用,不想其他插件似的,功能一大堆。好了,廢話不多說,還是看正文吧

工作需要一個JS分頁插件,心想自己動手寫一個吧,一來上網找一個不清楚代碼結構的,出了問題難以解決,而且網上的插件所包含的功能太多,有些根本用不到,就沒必要加載那段JS,二來想起沒寫過jQuery插件,就當練一下手了,好了,

 簡單說一下這個插件所要實現的功能

 后臺將查詢出來的內容全部顯示到頁面上,這個插件要控制這些內容,使其一頁一頁顯示。有上一頁,下一頁,首頁,尾頁的功能。在第一頁時,上一頁,首頁要隱藏。在最后一頁時,尾頁,下一頁要隱藏。一次只顯示幾個按鈕,當點擊當次最后一個按鈕時,顯示后面幾個。

 接下來簡單說一下編碼過程:

首先可以大膽的先寫下以下的代碼:

//為了更好的兼容性,開始前有個分號
;(
function($){//此處將$作為匿名函數的形參
}
)(jQuery)//將jQuery作為實參傳遞給匿名函數

這段代碼大家應該不陌生,就是javascript的神級特性---閉包。這也是jQuery插件的常見結構。為什么要使用閉包來作這jQuery的常用結構呢,一來既可以避免內部臨時變量影響全局空間,又可以在插件內部繼續使用$作為jQuery的別名。

接下來就是在這個結構里面寫自己的方法了,jQuery提供了兩種方式可以在jQuery里面擴展方法。打開jQuery API,找到插件機制,可以看到兩個方法

 

• jQuery.extend(object)  擴展jQuery對象本身。用來在jQuery命名空間上增加新函數。

• jQuery.fn.extend(object)  擴展 jQuery 元素集來提供新的方法(通常用來制作插件)。

從上面可以看到jQuery.extend(object)是擴展jQuery本身,要是參照java或者C#這些語言的角度來講,就相當于向jQuery中添加靜態方法。比如說我們這樣寫:

jQuery.extend({
 "max":function(){
  return max;
 }
})
 

這樣,就相當于在jQuery對象里面添加了一個max方法,調用的時候可以進行這樣調用:jQuery.max()

那么,jQuery.fn是什么呢,打開jQuery源碼,可以看到 jQuery.fn = jQuery.prototype。那么jQuery.fn.extend相當于在jQuery中添加成員函數。

這樣子應該明白兩者之間的區別了吧,靜態方法可以直接調用,jQuery.max()。成員函數只有jQuery實例可以調用,比如jQuery("#my").max()。

這里我采用jQuery.extend方法。代碼如下:

;(
 function($){
  $.extend({
   "easypage":function(options){
   options = $.extend({//參數設置
   contentclass:"contentlist",//要顯示的內容的class
   navigateid:"navigatediv",//導航按鈕所在的容器的id
   everycount:"5",//每頁顯示多少個
   navigatecount:"5"//導航按鈕一次顯示多少個
   }, options);
});
 

easypage就是使用分頁插件使用的方法名,contentclass,navigateid,everycount,navigatecount是參數。

基本框架已經搭好了,接下來就是完成功能。

首先是要找到要分頁的內容,并生成導航按鈕。代碼如下:

var currentpage = 0;//當前頁
var contents = $("."+options.contentclass);//要顯示的內容
var contentcount = contents.length;//得到內容的個數
var pagecount = Math.ceil(contentcount/options.everycount);//計算出頁數
//拼接導航按鈕
var navigatehtml = "<div id='pagefirst' class='pagefirst'><a href='javascript:void(0)'>首頁</a></div><div id='pagepre' class='pagepre'><a href='javascript:void(0)'>上一頁</a></div>";
for(var i = 1;i <= pagecount;i++){
 navigatehtml+='<div class="pagenavigate"><a href="javascript:void(0)">'+i+'</a></div>';
}
navigatehtml+="<div id='pagenext' class='pagenext'><a href='javascript:void(0)'>下一頁</a></div><div id='pagelast' class='pagelast'><a href='javascript:void(0)'>尾頁</a></div>";
 //加載導航按鈕

$("#"+options.navigateid).html(navigatehtml)

這段代碼比較簡單,就不多講。

接下來就是就是實現一些基本的功能,這里抽取其中兩個顯示

//隱藏所有的導航按鈕
$.extend({
"hidenavigates":function(){
//遍歷所有的導航按鈕
navigates.each(function(){
$(this).hide();
})
}
});
 
//顯示導航按鈕
$.extend({
"shownavigate":function(currentnavigate){
$.hidenavigates();
//當前按鈕如果小于要求一次顯示按鈕個數的,從0開始顯示
var begin = currentnavigate>=options.navigatecount?currentnavigate-parseInt(options.navigatecount):0;
//這里保證從第二頁開始,按鈕的個數都是2*options.navigatecount
if(begin>navigates.length-2*options.navigatecount){
begin = navigates.length-2*options.navigatecount;
}
//開始顯示
for(var i = begin;i < currentnavigate+parseInt(options.navigatecount);i++){
$(navigates[i]).show();
}
}
});
 

 好了,基本的代碼流程就是這樣了,程序的源代碼在附件中,具體的功能實現在源代碼注釋中已經解釋的挺清楚了。對于閉包還有疑問的,可以查看我上一篇博客,談談javascript閉包。

下面總結一下jQuery插件的基本要點,呵呵,從鋒利的jQuery中摘錄出來的。

•插件的文件名推薦為 jquery.[插件名].js,例如jquery.color.js
• 所有的對象方法都應當附加到jQuery.fn對象上,而所有的全局函數都應當附加到jQuery對象本身上

•在插件內部,this指向的是當前通過選擇器獲取的jQuery對象,而不像一般的方法那樣,例如click()方法,內部的this指向的是DOM元素

•可以通過this.each來遍歷所有元素
•所有的方法或函數插件,都應當以分號結尾,否則壓縮時可能出問題,有的為了更加穩妥些,在插件的開始處加上一個分號
•插件應該返回一個jQuery對象,這樣可以保證插件的可鏈式操作。除非插件需要返回的是一些需要獲取的量,例如字符串或者數組等
•盡量利用閉包技巧歷來避免變量名的沖突
 

因為第一次寫jQuery插件,可能會有一些地方說的不對,請大家包涵。

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久久久久久久国产| 亚洲国内精品视频| 亚洲女同性videos| 欧美高清视频在线播放| 国产一区二区三区日韩欧美| 国产精品天天狠天天看| 精品成人乱色一区二区| 国产精品小说在线| 久久韩剧网电视剧| 91极品视频在线| 成人精品aaaa网站| 亚洲性视频网站| 97成人精品视频在线观看| 日本久久久a级免费| 日韩电影免费观看在线| 97在线看免费观看视频在线观看| 亚洲最大成人网色| 亚洲视频网站在线观看| xxxx性欧美| 欧美激情精品久久久| 91精品国产综合久久香蕉922| 亚洲精品电影在线观看| 精品久久久久久久久久国产| 久久久久久国产| 久久久久国产精品一区| 91麻豆国产语对白在线观看| 亚洲免费小视频| 国产成人精品综合久久久| 久久亚洲精品中文字幕冲田杏梨| 精品自在线视频| 久久久久久久久爱| 狠狠躁夜夜躁人人爽天天天天97| 精品国产一区久久久| 国产成人高清激情视频在线观看| 欧美壮男野外gaytube| 一区二区三区天堂av| 日韩av电影免费观看高清| www.国产精品一二区| 成人一区二区电影| 欧美极品在线视频| 国产精品视频26uuu| 国产精品一区二区三区毛片淫片| 91国产精品视频在线| 久久久久久久久久久免费| 亚洲男人天堂手机在线| 亚洲高清久久网| 疯狂做受xxxx高潮欧美日本| 2018日韩中文字幕| 国产精品99久久久久久久久久久久| 欧洲午夜精品久久久| 人人澡人人澡人人看欧美| 欧美日韩国产一区二区| 日韩欧美在线视频免费观看| 久久综合久久88| 亚洲国产精彩中文乱码av在线播放| 国产精品久久久999| 色yeye香蕉凹凸一区二区av| 久久久精品免费| 免费成人高清视频| 国产美女被下药99| 国产精品第3页| 欧美性生活大片免费观看网址| 91在线高清视频| 亚洲欧美日韩图片| 亚洲精品天天看| 久久亚洲欧美日韩精品专区| 国产va免费精品高清在线观看| 日韩在线视频免费观看高清中文| 亚洲欧美日韩一区二区三区在线| 亚洲欧美在线一区| 久久成人av网站| 久久久久久中文| 亚洲精品98久久久久久中文字幕| 国产精品久久久久久久久影视| 色噜噜国产精品视频一区二区| 国产精品一区二区三区成人| 欧美激情二区三区| 国产精品高潮呻吟久久av黑人| 国产精品夜色7777狼人| 色999日韩欧美国产| 最近的2019中文字幕免费一页| 深夜精品寂寞黄网站在线观看| 夜夜躁日日躁狠狠久久88av| 成人免费直播live| 国产欧美亚洲精品| 欧美激情精品久久久久久免费印度| 97国产suv精品一区二区62| 久久精品在线播放| 亚洲男人的天堂网站| 日韩国产激情在线| 亚洲一区精品电影| 欧美亚洲视频在线观看| 日韩中文字幕在线免费观看| 色综合色综合网色综合| 成人av电影天堂| 欧美限制级电影在线观看| 国内免费久久久久久久久久久| 中文字幕久热精品在线视频| 国产精品99久久久久久白浆小说| 欧美又大又粗又长| 亚洲欧美另类国产| 国产精品伦子伦免费视频| 久久精品一本久久99精品| 色综合伊人色综合网站| 国产精品人成电影| 日韩精品在线视频观看| 国产欧美日韩精品丝袜高跟鞋| 4p变态网欧美系列| 亚洲一区美女视频在线观看免费| 一区二区国产精品视频| 欧美精品videos| 国产精品久久久久久久久| 亚洲欧美制服中文字幕| yellow中文字幕久久| 精品久久久久久久久久国产| 国产999精品久久久影片官网| 日本成人精品在线| 精品无人区乱码1区2区3区在线| 成人午夜高潮视频| 久久精品亚洲94久久精品| 国产精品成人一区二区三区吃奶| 5566日本婷婷色中文字幕97| 久久久女人电视剧免费播放下载| 亚洲精品久久久久国产| 午夜精品一区二区三区在线视频| 欧美夜福利tv在线| 57pao精品| 91香蕉嫩草神马影院在线观看| 精品日韩中文字幕| 欧美成人h版在线观看| 日韩a**站在线观看| 亚洲欧美日韩天堂一区二区| 久久久久中文字幕2018| 欧美三级xxx| 日韩精品免费在线观看| 国产精品久久久久久久久久久新郎| 亚洲成色777777在线观看影院| 日韩av成人在线| 久久久精品一区二区| 久久国产精品偷| 国产精品视频区1| 亚洲欧美日韩天堂一区二区| 亚洲欧美中文字幕| 亚洲欧美国产另类| 精品一区电影国产| 久久精品国产一区二区三区| 久久综合色88| 欧美日韩亚洲国产一区| 亚洲电影免费观看高清完整版| 欧美日韩加勒比精品一区| 在线日韩中文字幕| 精品久久久久久久久久| 国产日韩在线免费| 国产精品亚洲精品| 色综合天天狠天天透天天伊人| 久久久国产影院| 国产精品香蕉国产| 欧美在线视频网站| 国产一区二区三区在线免费观看| 国产一区二中文字幕在线看| 亚洲图片制服诱惑| 色哟哟亚洲精品一区二区| 午夜精品福利视频| 久久国产精品久久久久久久久久|