jquery 插件 阅读

1.重要概念 :变量(数据)  ,函数 ,对象,原型 ,继承
2.两个jquery变量
// 全局 jQuery
var jQuery = (function() {
   // 局部 jQuery
   var jQuery = function( selector, context ) {
// ...
   }
})();
3.变量保存数据,函数也是数据
JavaScript中的函数实际上是数据。也就是说,通过以下两种方式定义jQuery函数,结果是相同的:


// 局部 jQuery
function jQuery( selector, context ){
   //...
}
// 局部 jQuery
var jQuery = function( selector, context ){
   //...
}
4.匿名函数
举个例子,下面的函数在页面加载时会自动执行,你可以在控制台看到输出:


var jQuery = (function() {
   console.log("I am self-invoking.");
})();
那为什么要像这样来使用匿名函数呢?因为这样可以在不创建全局变量的情况下执行一些内部操作。jQuery使用匿名自调用函数来完成它的一次性初始化。
5.对象
对象的概念:


包含对象的变量名叫 XXX
对象的内容被包含在 { 和 } 中
对象的元素(属性和方法)用逗号来分隔
键/值对用冒号分隔,比如 key : value(或者上面例子中的 hair : "black")
方法实际上也是函数,比如 ridingUnicorn 就是对象 shichuan 的一个方法(函数)
例如一个对象
var shichuan = {
   hair: "black",
   ridingUnicorn: function() {
// 我怎么骑独角兽
 }
};
6.jquery中的对象
var jQuery = function( selector, context ) {
   // jQuery对象实际上就是一个“增强版的”init构造函数
   return new jQuery.fn.init( selector, context, rootjQuery );
}
7.函数是数据,也是对象
// 局部 jQuery
function jQuery( selector, context ){
   //...
}
// 局部 jQuery
var jQuery = function( selector, context ){
   //...
}
// 局部 jQuery
var jQuery = new Function('selector', 'context', '//...');




8.jquery.extend 函数详解
JQuery的extend扩展方法:
      Jquery的扩展方法extend是我们在写插件的过程中常用的方法,该方法有一些重载原型,在此,我们一起去了解了解。
      一、Jquery的扩展方法原型是:   


 extend(dest,src1,src2,src3...);


      它的含义是将src1,src2,src3...合并到dest中,返回值为合并后的dest,由此可以看出该方法合并后,是修改了dest的结构的。如果想要得到合并的结果却又不想修改dest的结构,可以如下使用:


  var newSrc=$.extend({},src1,src2,src3...)//也就是将"{}"作为dest参数。


      这样就可以将src1,src2,src3...进行合并,然后将合并结果返回给newSrc了。如下例:


var result=$.extend({},{name:"Tom",age:21},{name:"Jerry",sex:"Boy"})
 


      那么合并后的结果


  result={name:"Jerry",age:21,sex:"Boy"}


  9. 省略dest参数
      上述的extend方法原型中的dest参数是可以省略的,如果省略了,则该方法就只能有一个src参数,而且是将该src合并到调用extend方法的对象中去,如:
   1、$.extend(src)
   该方法就是将src合并到jquery的全局对象中去,如:


 $.extend({
  hello:function(){alert('hello');}
  });


   就是将hello方法合并到jquery的全局对象中。
   2、$.fn.extend(src)
   该方法将src合并到jquery的实例对象中去,如:


 $.fn.extend({
  hello:function(){alert('hello');}
 });
 


   就是将hello方法合并到jquery的实例对象中。


  就是将hello方法合并到jquery的实例对象中。


   下面例举几个常用的扩展实例:


$.extend({net:{}});
 


   这是在jquery全局对象中扩展一个net命名空间。


  $.extend($.net,{
   hello:function(){alert('hello');}
  })


    这是将hello方法扩展到之前扩展的Jquery的net命名空间中去。


  11. Jquery的extend方法还有一个重载原型:  


extend(boolean,dest,src1,src2,src3...)


      第一个参数boolean代表是否进行深度拷贝,其余参数和前面介绍的一致,什么叫深层拷贝,我们看一个例子:


var result=$.extend( true,  {},  
    { name: "John", location: {city: "Boston",county:"USA"} },  
    { last: "Resig", location: {state: "MA",county:"China"} } ); 


      我们可以看出src1中嵌套子对象location:{city:"Boston"},src2中也嵌套子对象location:{state:"MA"},第一个深度拷贝参数为true,那么合并后的结果就是: 


result={name:"John",last:"Resig",
        location:{city:"Boston",state:"MA",county:"China"}}
 


       也就是说它会将src中的嵌套子对象也进行合并,而如果第一个参数boolean为false,我们看看合并的结果是什么,如下:


var result=$.extend( false, {},  
{ name: "John", location:{city: "Boston",county:"USA"} },  
{ last: "Resig", location: {state: "MA",county:"China"} }  
                    ); 


     那么合并后的结果就是:


  result={name:"John",last:"Resig",location:{state:"MA",county:"China"}}
 


  以上就是$.extend()在项目中经常会使用到的一些细节。


12.
使用命名空间


虽然在jQuery命名空间中,我们禁止使用了大量的javaScript函数名和变量名。但是仍然不可避免某些函数或变量名将于其他jQuery插件冲突,因此我们习惯将一些方法封装到另一个自定义的命名空间。


jQuery.myPlugin = {         
 foo:function() {         
   alert('This is a test. This is only a test.');         
  },         
  bar:function(param) {         
   alert('This function takes a parameter, which is "' + param + '".');   
  }        
 }; 
采用命名空间的函数仍然是全局函数,调用时采用的方法: 
$.myPlugin.foo();        
$.myPlugin.bar('baz');
通过这个技巧(使用独立的插件名),我们可以避免命名空间内函数的冲突。


13.插件设置
$.fn.hilight = function(options) { 
  // Extend our default options with those provided. 
  // Note that the first arg to extend is an empty object - 
  // this is to keep from overriding our "defaults" object. 
  var opts = $.extend({}, $.fn.hilight.defaults, options); 
  // Our plugin implementation code goes here. 
}; 
// plugin defaults - added as a property on our plugin function 
$.fn.hilight.defaults = { 
  foreground: 'red', 
  background: 'yellow' 
};  
现在使用者可以包含像这样的一行在他们的脚本里:
//这个只需要调用一次,且不一定要在ready块中调用
$.fn.hilight.defaults.foreground = 'blue'; 
接下来我们可以像这样使用插件的方法,结果它设置蓝色的前景色:
$('#myDiv').hilight(); 
如你所见,我们允许使用者写一行代码在插件的默认前景色。而且使用者仍然在需要的时候可以有选择的覆盖这些新的默认值:
// 覆盖插件缺省的背景颜色
$.fn.hilight.defaults.foreground = 'blue';
// ...
// 使用一个新的缺省设置调用插件
$('.hilightDiv').hilight();
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值