jQuery插件开发语法小结

    jQuery插件开发中经常会看到$.extend({....});   $.fn.extend({...});  (function($){...})(jQuery);这些结构,这里简单总结一下这些语法的意义。

一、(function($){...})(jQuery);表达式的含义:

  • 这句话的意思简单的说就是一个是匿名函数。

    function(arg){...}定义了一个匿名函数,参数为arg。而调用函数时,需要在函数后面写上括号和实参的,由于操作符的优先级,函数本身也需要用括号,即:(function(arg){...})(param)。这就相当于定义了一个参数为arg的匿名函数,并且将param作为参数来调用这个匿名函数。

    (function($){...}) (jQuery)中,之所以只在形参使用$,是为了不与其他库冲突,所以实参用jQuery。

    上面的语法其实等于var fn = function($){....};和fn(jQuery);的简化,不过要注意的是fn是不存在的。这个函数直接定义,然后就运行了,就“压缩”成这个样子(function($){...})(jQuery) 了。

  • 对比$(function(){ }:

  • $(function(){});全写为$(docunemt).ready(function(){});意义为在DOM加载完毕后执行ready()方法。用来在DOM加载完成之后运行,执行那些预行定义好的函数。
  • (function($){....})(jQuery) 用来定义一些需要预先定义好的函数,立即执行匿名函数()(param),只不过参数是jQuery对象等价于:var a = function(params){....};a(jQuery);

二、$.extend({....});和$.fn.extend({...});的作用及区别:

        这是jQuery为开发插件提拱的两个方法,我们采用面向对象的思想来理解起来比较容易。jQuery便是一个封装得非常好的类,比如我们用语句$("#btn") 会生成一个 jQuery类的实例。

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

jQuery.extend({
	min: function(a, b) { return a < b ? a : b; },
	max: function(a, b) { return a > b ? a : b; }
});

jQuery.min(2,3); //  2 
jQuery.max(4,5); //  5

  • ObjectjQuery.extend( target, object1, [objectN])用一个或多个其他对象来扩展一个对象,返回被扩展的对象。
var settings = { validate: false, limit: 5, name: "foo" };
var options = { validate: true, name: "bar" }; 
jQuery.extend(settings, options);
settings == { validate: true, limit: 5, name: "bar" } //结果
  • jQuery.fn.extend(object); 对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。
比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:

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

$("#input1") 为一个jQuery实例,当它调用成员方法 alertWhileClick后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。
三、jQuery插件小结:
  • 先看 jQuery(function(){ }); 全写为 jQuery(document).ready(function(){ }); 意义为在DOM加载完毕后执行了eady()方法。
  • 再看 (function(){ })(jQuery);其实际上是执行()(para)匿名方法,只不过是传递了jQuery对象。 
  • jQuery(function(){ });用于存放操作DOM对象的代码,执行其中代码时DOM对象已存在。不可用于存放开发插件的代码,因为jQuery对象没有得到传递,外部通过jQuery.method也调用不了其中的方法(函数)。 
  • (function(){ })(jQuery);用于存放开发插件的代码,执行其中代码时DOM不一定存在,所以直接自动执行DOM操作的代码。

你可能感兴趣的:(jQuery插件开发语法小结)