JQuery Pagenation 知识点整理——$.extend(),与$.fn.extend()应用(20150517)

jQuery为开发插件提拱了两个方法,分别是:

jQuery.fn.extend();

jQuery.extend();

 

一、 $.extend()方法

$.extend()方法在JQuery中有两个用法:

第一种是Jquery的扩展方法:

实例:

虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便。

jQuery便是一个封装得非常好的类,比如我们用 语句 $("#btn1") 会生成一个 jQuery类的实例。

jQuery.extend(object); 为jQuery类添加类方法,可以理解为添加静态方法。如:

 1 jQuery.extend({
 2 
 3 min: function(a, b) { return a < b ? a : b; },
 4 
 5 max: function(a, b) { return a > b ? a : b; }
 6 
 7 });
 8 
 9 jQuery.min(2,3); //  2 
10 jQuery.max(4,5); //  5

 

拓展方法(一)

 1 $(function(){
 2 jQuery.extend({
 3 modalshow: function (options) {
 4 var defaults = {
 5 triggerID: ‘LoginShow‘,
 6 callback: function () { }
 7 }<br>       //这里是$.extend的第二种用法<br>       var opts = $.extend({},defaults, options);
 8 if ($("#" + opts.triggerID)[0] == null) {
 9 var $triggerBTN = $(‘<input type="button" value="LoginShow" id=‘ + opts.triggerID + ‘/>‘);
10 $triggerBTN.bind("click", function () {
11 alert(opts.triggerID);
12 });
13 $("body").append($triggerBTN);
14 } else {
15 $("#" + opts.triggerID).bind("click", function () {
16 alert(opts.triggerID);
17 })
18 }
19 }
20 });
21 $.modalshow();//这里是调用的地方,id为‘loginshow‘的button可以先不再HTML中添加可以自动生成
22 })

 

拓展方法(二)

 1 $(function(){
 2 jQuery.fn.extend({
 3 modalshow: function (options) {
 4 var defaults = {
 5 //这里的this是JQuery对象
 6 triggerID: this.attr("id"),
 7 callback: function () { }
 8 }<br>       //这里是$.extend的第二种用法<br>       var opts = $.extend(defaults, options);
 9 $("#" + opts.triggerID).bind("click", function () {
10 alert(opts.triggerID);
11 })
12 }
13 });
14 $("#loginShow").modalshow();//这里是调用的地方,这里需要先在HTML中加入元素
15 })

 

 

第二个方法是递归合并方法:

jQuery.extend([deep], target, object1, [objectN])

返回值:Object

把2个对象合并得到新的target,deep是可选的(递归合并)

实例(一)

描述:

合并 settings 和 options,修改并返回 settings。

1 var settings = { validate: false, limit: 5, name: "foo" };
2 var options = { validate: true, name: "bar" };
3 jQuery.extend(settings, options);

返回结果:

settings == { validate: true, limit: 5, name: "bar" }

 

实例(二)

描述:

合并 defaults 和 options, 不修改 defaults。

1 var empty = {};
2 var defaults = { validate: false, limit: 5, name: "foo" };
3 var options = { validate: true, name: "bar" };
4 var settings = jQuery.extend(empty, defaults, options);

返回结果:

settings == { validate: true, limit: 5, name: "bar" }
empty == { validate: true, limit: 5, name: "bar" }

 

实例(三)

//Jquery Pagenation 分页插件代码片段:

1 defaultOption={debug=false,firstBtnText=null,infoFormat="{start}~{end} of {total} entires",jumpbtnText="Go",lastBtnText=null,loadFirstPage=true,showFirstLastBtn=true,nextBtnText="&raquo;",pageBtnCount=11,pageSize=10,pageSizeItems=null,preBtnText="&laquo;",remote={pageIndexName="pageIndex",pageSizeName="pageSize",param=null,totalName="total",url=null,callback=null,},showInfor=false,showJump=false,showPageSize=false};
2 
3 $.fn.page.defaults=undefind;
4 
5 options={total=352,showInfo=true, showjump=true,showPageSizes=true};
6 
7 this.options = $.extend(true, {}, defaultOption, $.fn.page.defaults, options);

 

返回结果:

this.options={debug=false,firstBtnText=null,infoFormat="{start}~{end} of {total} entires",jumpbtnText="Go",lastBtnText=null,loadFirstPage=true,showFirstLastBtn=true,nextBtnText="&raquo;",pageBtnCount=11,pageSize=10,pageSizeItems=null,preBtnText="&laquo;",remote={pageIndexName="pageIndex",pageSizeName="pageSize",param=null,totalName="total",url=null,callback=null,},showInfor=true,showJump=true,showPageSize=true,total=352}

 

二、 jQuery.fn.extend(object) 的用法:

jQuery.fn.extend(object); 对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。

比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:

$.fn.extend({          
     alertWhileClick:function() {            
           $(this).click(function(){                 
                  alert($(this).val());           
            });           
      }       
});       
$("#input1").alertWhileClick(); // 页面上为:    

$("#input1") 为一个jQuery实例,当它调用成员方法 alertWhileClick后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。


 参考出处:http://blog.csdn.net/xylike816/article/details/6704119

                http://blog.sina.com.cn/s/blog_7c5d61f30101da1k.html

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。