jQuery定义插件的方法
有些WEB开发者,会引用一个JQuery类库,然后在网页上写一写$("#"),$("."),写了几年就对别人说非常熟悉JQuery。我曾经也是这样的人,直到有一次公司里的技术交流,我才改变了自己对自己的看法。
扩展jquery的时候。最核心的方法是以下两种:
$nd(object) 可以理解为jquery添加一个静态方法
$nd(object) 可以理解为jquery实例添加一个方法
$nd(object)
例子:
/* $nd 定义与调用* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */$nd({ fun: function () { alert("执行方法一"); } });//定义$();//调用$ntd(object)/* $nd 定义与调用* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */$nd({ fun: function () { alert("执行方法"); } });$(this)();//等同于$ = function () { alert("执行方法三"); }$(this)();
定义jquery插件的基本结构
1. 定义作用域:
为插件定义一个私有作用域。外界代码不能直接访问插件内部。插件内部代码不受外界干扰,也不会污染到全局变量。
//step 定义JQuery的作用域(function ($) {})(jQuery);
2. 为插件添加扩展方法:
//step01 定义JQuery的作用域(function ($) { //step02 插件的扩展方法名称 $Slider = function (options) { }})(jQuery);
3. 设置默认值:
//step 定义JQuery的作用域(function ($) { //step-a 插件的默认值属性 var defaults = { prevId: ‘prevBtn‘, prevText: ‘Previous‘, nextId: ‘nextBtn‘, nextText: ‘Next‘ //…… }; //step 插件的扩展方法名称 $Slider = function (options) { //step-b 合并用户自定义属性,默认属性 var options = $nd(defaults, options); }})(jQuery);
其中:var options = $nd(defaults, options)的含义了。表示 options 去覆盖了defaults的'值,并把值赋给了options。
在插件环境中,就表示用户设置的值,覆盖了插件的默认值;如果用户没有设置默认值的属性,还是保留插件的默认值。
4. 支持jquery选择器:
//step 定义JQuery的作用域(function ($) { //step-a 插件的默认值属性 var defaults = { prevId: ‘prevBtn‘, prevText: ‘Previous‘, nextId: ‘nextBtn‘, nextText: ‘Next‘ //…… }; //step 插件的扩展方法名称 $Slider = function (options) { //step-b 合并用户自定义属性,默认属性 var options = $nd(defaults, options); //step 支持JQuery选择器 (function () { }); }})(jQuery);
5 .支持JQuery的链接调用:
为了能达到链接调用的效果必须要把循环的每个元素return
//step 定义JQuery的作用域(function ($) { //step-a 插件的默认值属性 var defaults = { prevId: ‘prevBtn‘, prevText: ‘Previous‘, nextId: ‘nextBtn‘, nextText: ‘Next‘ //…… }; //step 插件的扩展方法名称 $Slider = function (options) { //step-b 合并用户自定义属性,默认属性 var options = $nd(defaults, options); //step 支持JQuery选择器 //step 支持链式调用 return (function () { }); }})(jQuery);
6. 插件里的方法:
在插件里定义的方法,外界不能直接调用,我在插件里定义的方法也没有污染外界环境。
//step01 定义JQuery的作用域(function ($) { //step03-a 插件的默认值属性 var defaults = { prevId: ‘prevBtn‘, prevText: ‘Previous‘, nextId: ‘nextBtn‘, nextText: ‘Next‘ //…… }; //step06-a 在插件里定义方法 var showLink = function (obj) { $(obj)nd(function () { return "(" + $(obj)("href") + ")" }); } //step02 插件的扩展方法名称 $Slider = function (options) { //step03-b 合并用户自定义属性,默认属性 var options = $nd(defaults, options); //step4 支持JQuery选择器 //step5 支持链式调用 return (function () { //step06-b 在插件里定义方法 showLink(this); }); }})(jQuery);
通过以上内容给大家介绍了jQuery定义插件的方法,希望大家喜欢。
-
平面广告中使用图形创意的作用
提起平面广告相信许多小伙伴们都不会感到陌生吧,在于一些产品来说,打广告太常见了,可以起到很好的宣传作用,以下是小编给大家带来的平面广告中使用图形创意的作用,希望对大家有帮助。视觉设计又可以称之为图形设计,是VisualCommunicationDesign的中文翻译。有时在西...
-
移动硬盘突然识别不了
导语:移动硬盘顾名思义是以硬盘为存储介质,计算机之间交换大容量数据,强调便携性的存储产品,系统不能识别移动硬盘怎么办呢?在正常情况下,移动硬盘同主机相连后系统即可将它认成“移动存储设备”,并自动在“我的电脑”中添加盘符。如果系统将移动硬盘认成“未知的USB...
-
Excel中批量删除超链接的方法
Excel中某列单元格均含有超链接,数量巨大,因此只能考虑采用批量删除法,下面跟小编学习一下批量删除超链接的方法。一、宏代码去除法打开该Excel文件,切换到视图选项卡,点击宏→录制宏,出现录制新宏窗口,在宏名定义一个名称为:RemoveHyperlinks(图2),点击确定退出;再...
-
SEO常见术语
链接场(LinkFarm)在SEO术语中,链接场是指一个充满链接的页面,这些链接其实没有实际作用,它们只作为链接存在,而没有任何实际的上下文。那些采用运用黑帽SEO方法的人利用链接场,在一个页面中增加大量链接,希望能通过这种方式使Google误认为这个页面很有链接的价值。交...