jQuery插件制作之全局函数使用方法
1、添加新的全局函数
所谓的全局函数,实际上就是jQuery对象的方法,但从实践的角度上看,他们是位于jQuery命名空间内部的函数
(1)添加一个函数,只需要将新函数指定为jQuery对象的一个属性。
=function(){ alert("直接继承方式不一样"); }
调用:复制代码 代码如下:$();
(2)添加多个函数
=function(){ alert("直接继承方式不一样"); } =function(){ alert("直接继承方式不一样2"); }
调用:复制代码 代码如下:$();$();
以上的方法会面临命名空间冲突的风险,为避免这个问题,最好把属于这个插件的所有全局函数,都封装到一个对象中,如下:
//命名空间继承 ugin ={ one : function(obj){ var object = obj; var id = ("id"); alert(id); }, two : function(){ alert(22); } }
这样其实是为全局函数创建了另一个命名空间:ugin.
2、添加jQuery对象方法
jQuery中大多数内置的功能都是通过其对象的方法提供的。
thod= function(){ alert(11); }
调用:复制代码 代码如下:$thod();
注意:是otype的别名。
实例:以下是行为不正确的方法
11111111111111111111111111
22222222222222222222
333333333333333
4444444444444444455555555555555
6666666666666666
777777777777777777
777777777777777777
Class= function(class1,class2){ if(lass(class1)){ veClass(class1)lass(class2); } if(lass(class2)){ veClass(class2)lass(class1); } } $("#swap")k(function(){ $("li")Class("this","that"); return false; })
全部li都是用了that样式。
(1)隐士迭代
要在无论匹配多个元素的情况下都保证行为的正确,最简单的方法是始终在方法的环境上调用()方法,这样就会
执行隐士迭代,而执行隐士迭代对于维护插件和内置方法的一致性是至关重要的,在调用的()方法内部,this
依次引用的.是每个DOM元素.以上代码修改为:
Class= function(class1,class2){ (function(){ var $element = jQuery(this); if($lass(class1)){ $veClass(class1)lass(class2); }else if($lass(class2)){ $veClass(class2)lass(class1); } }) }
调用:
复制代码 代码如下:$("li")Class("this","that")
(2)方法的连缀
要使用方法的连缀,必须在所有的插件方法中返回一个jQuery对象。返回的jQuery对象通常就是this所引用的对象。
Class= function(class1,class2){ return (function(){ var $element = jQuery(this); if($lass(class1)){ $veClass(class1)lass(class2); }else if($lass(class2)){ $veClass(class2)lass(class1); } }) }
调用:
复制代码 代码如下:$("li")Class("this","that")("text-decoration","underline");
3、添加新的简写方法
//添加新的简写方法 eFadeOut= function(speed,callback){ return ate({ height : "hide", opacity : "hide" },speed,callback) } eFadeIn= function(speed,callback){ return ate({ height : "show", opacity : "show" },speed,callback) } eFadeToggle= function(speed,callback){ return ate({ height : "toggle", opacity : "toggle" },speed,callback) }
-
网页设计的布局
网页设计的工作目标,是通过使用更合理的颜色、字体、图片、样式进行页面设计美化,在功能限定的情况下,尽可能给予用户完美的视觉体验。以下是小编为您带来的网页设计的布局,看看吧!网页设计的布局11、响应式网页设计响应式网页设计是网页设计的一种技术,可在N多种浏...
-
万恶的function在javascript中的运用实例分析
javascript中最有特色而又让你困惑的function算一个了下面看一下常用操作复制代码代码如下:functiondoit(){.....}doit();javascript中的函数我们可以把它当作方法使用复制代码代码如下:varobj=newObject();=function(){.....}();而function实际上就是对象(即F...
-
如何理解Javascript的caller,callee,call,apply区别
在提到上述的概念之前,首先想说说javascript中函数的隐含参数:argumentsarguments该对象代表正在执行的函数和调用它的函数的参数。[function.]arguments[n]参数function:选项。当前正在执行的Function对象的名字。n:选项。要传递给Function对象的从0开始的参数值...
-
讲解HTML中iframe和frame的区别
不知道你在项目中用过frameset属性没有,frameset这个属性是在去年我在一个在线客服系统制作中用过,因为客服系统要有固定的布局,上面一块,下面一块等等,当时就是用的frameset和frame。在我用完了这些属性之后,我才明白了iframe和frame的`区别。因为在这之前,我项目中...