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

时间: 2024-08-03 20:54:19

JQuery Pagenation 知识点整理——$.extend(),与$.fn.extend()应用(20150517)的相关文章

JQuery添加扩展方法(理解$.extend(),与$.fn.extend()方法区别)

理解$.extend(),与$.fn.extend()方法区别 1.$.extend()方法 $.extend()方法在JQuery中有两个用法,第一次是扩展方法, 第二个方法是 jQuery.extend([deep], target, object1, [objectN]) 返回值:Object 把2个对象合并得到新的target,deep是可选的(递归合并) 合并 settings 和 options,修改并返回 settings. jQuery 代码: var settings = {

jQuery中 $.extend 和 $.fn.extend 解释

$.extend() (1)第一种:拓展jQuery的全局(静态)函数的 方式:--->一个参数 例如: $.extend({ add : function(){ alert("1"); }, miu : function(){ alert("2"); } }) //此方式在jQuery对象本身:可以通过 jQuery.add(), jQuery.miu() 直接调用: (2)第二种:对象合并,即可以实现某个函数的重载:--->多个参数 例如: var

$.extend()和$.fn.extend()函数用法简单介绍

$.extend()和$.fn.extend()函数用法简单介绍:标题中的两个方法在jQuery插件开发中非常的重要,下面通过简单的代码实例介绍一下它们的用法.本章节不会介绍它的原理,而是只给出它们的作用是什么,能够做什么事情.jQuery.extend()可以为jQuery类添加新的方法,类似于c#或者java中的静态方法.jQuery.fn.extend()可以为jQuery的对象实例添加新的方法.代码实例: <!DOCTYPE html> <html> <head>

插件的理解$.extend()与$.fn.extend()

插件的理解.$.extend()与$.fn.extend()    插件开发包括两种:1.类级别的插件开发,即$.extend()扩展jquery对象本身:2.对象级别的插件开发,即$.fn.extend()扩展jquery元素集来提供新的方法.    1.类级别的插件开发        1.(function($){                $.extend({                    hello:function(){alert("hello world");}

js插件 $.extend()与$.fn.extend() 基础

插件的理解.$.extend()与$.fn.extend()    插件开发包括两种:1.类级别的插件开发,即$.extend()扩展jquery对象本身:2.对象级别的插件开发,即$.fn.extend()扩展jquery元素集来提供新的方法.    1.类级别的插件开发        1.(function($){                $.extend({                    hello:function(){alert("hello world");}

$.extend(),与$.fn.extend() 讲解

$.extend(),与$.fn.extend() 讲解(一) (2013-07-11 10:24:31) 转载▼ 转自:http://blog.sina.com.cn/s/blog_a3bd3bd0010187y1.html     jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级别的插件开发,即给jQuery对象添加方法.下面就两种函数的开发

$.extend()和$.fn.extend()区别

$.extend()和$.fn.extend()用法和区别: 在自己制作插件的时候会经常用到$.extend()和$.fn.extend()两个函数,无论从外观还是作用都非常的类似,但是实际上它们的区别是巨大的,下面就简单介绍一下它们的区别是什么. 在javascript中,没有尽管没有类这个概念,但是作为一门面向对象的语言,其实是有着类似于类的实际应用,那么从标准面向对象的概念来说,jQuery就是一个封装好了的jQuery类,那么通过选择器获得的就是jQuery对象实例. 一.$.exten

jquery的extend和fn.extend

jQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(object); jQuery.extend(object); jQuery.extend(object); 为扩展jQuery类本身.为类添加新的方法. jQuery.fn.extend(object);给jQuery对象添加方法. fn 是什么东西呢.查看jQuery代码,就不难发现. jQuery.fn = jQuery.prototype = { init: function( selector, cont

jquery的$.extend和$.fn.extend作用及区别

jQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(); jQuery.extend(); 虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便. jQuery便是一个封装得非常好的类,比如我们用 语句 $("#btn1") 会生成一个 jQuery类的实例. jQuery.extend(object); 为jQuery类添加类方法,可以理解为添加静态方法.如: jQuery.extend({ min: function(a, b)