jQuery插件开发学习笔记

简介:

  今天想了解一下jQuery的插件开发,于是google了一下,列在前面的两篇文章都很不错,jQuery插件开发全解析 更是将插件开发的方方面面细致入微的进行了讲解,并提供了PDF进行下载。笔者今天详细的阅读了这篇文章并记录了一些笔记。

 

  1.类级别的插件开发

  我是这样理解的:jQuery是类,$是jQuery的别名,$('selector')为jQuery对象

  这种插件类似为jQuery类添加静态的方法,然后我们就可以像在C#中调用静态方法一样使用插件。添加静态方法的途径有两种:

复制代码
jQuery.alert = function () {
alert("这是一个jQuery的提示框");
}

jQuery.confirm = function () {
confirm("这是一个JQuery的提示框");
}
复制代码

 

  相应的调用:$.alert(); $.confirm();

  另一种方法的代码如下:

jQuery.extend({
alert: function () { alert("这是一个jQuery的提示框"); },
confirm: function () { confirm("这是一个JQuery的提示框"); }
});

  这种是通过jQuery提供的extend方法进行功能的扩展,调用的方法同上。

  另外,为了避免与其它jQuery插件的冲突,我们可以添加自己的命名空间:

jQuery.sample = {
alert: function () { alert("这是一个jQuery的提示框"); },
confirm: function () { confirm("这是一个JQuery的提示框"); }
};

  添加了命名空间后的调用:$.sample.alert(); $.sample.confirm();

  2.对象级别的插件开发

复制代码
/*

这种写法的说明:
var fn = function(para){
//code...
}
fn(jQuery);

先定义一个方法,再立即执行这个方法
这种写法的好处:我们在写jQuery插件时,也可以使用$这个别名,而不会与prototype引起冲突.

*/
(function ($) {
$.fn.extend({
hilight: function (options) {
var opts = $.extend($.fn.hilight.defauts, options);
this.css("color", opts.color).css("background-color", opts.bgcolor);
}
});

$.fn.hilight.defauts = {
color: 'red',
bgcolor: 'white'
};
})(jQuery);
复制代码

  jQuery推荐这种写法,好处就在上面的注释部分。

  在这段代码中我们将defaults暴漏出来,允许用户直接访问并设置defaults值,这样做的好处,是只需要在一处设置默认值以后,别处都可以直接使用,而不用每次传递参数。当然,我们仍然可以传递参数,以改变手工设置的默认值。

  我们还可以通过暴漏defaults的相同方法来暴漏一些可供别人扩展的方法;如果需要将一个方法或属性私有化,只需要在闭包中定义,而不要提供相应的引用。

 

  3.总结

  jQuery为开发插件提拱了两个方法,分别是:

    jQuery.fn.extend(object); 给jQuery对象添加方法。fn 是什么东西呢?原来 jQuery.fn = jQuery.prototype,jQuery.fn.extend(object)是对jQuery.prototype进行的扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。

    jQuery.extend(object); 为扩展jQuery类本身.为类添加新的方法。可以理解为jQuery添加静态方法。

  

  最后提供相应的pdf下载:《jQuery插件开发全解析》

  




本文转自齐师傅博客园博客,原文链接:http://www.cnblogs.com/youring2/archive/2012/04/05/2433483.html,如需转载请自行联系原作者

相关文章
|
存储 JavaScript 前端开发
JQuery最最最详细的第一课
JQuery最最最详细的第一课
80 0
|
4月前
|
JavaScript 前端开发
网页前端课程设计-【模仿】香港中文大学官网,轮播图及div+css布局,js的dom操作
这篇文章介绍了如何模仿香港中文大学官网进行网页前端课程设计,包括使用div+css布局、js的DOM操作以及实现轮播图等技术细节。
|
7月前
|
JavaScript 前端开发
杨校老师课堂之Web前端JS类库_JQuery案例[效果图与代码齐全]
杨校老师课堂之Web前端JS类库_JQuery案例[效果图与代码齐全]
43 0
|
8月前
|
XML 前端开发 JavaScript
前端CSS样式零基础教学总结,UI、前端开发都适用
前端CSS样式零基础教学总结,UI、前端开发都适用
108 2
|
JavaScript
jQuery插件开发
jQuery插件开发
82 0
|
前端开发 JavaScript iOS开发
8款超赞的最新jQuery插件工具
jQuery是迄今为止我最喜欢的Javascript框架,开发者用jQuery创造出惊人的视觉效果,以及处理数据,等等。 在这篇文章中,我给所有web开发人员推荐8款超赞的jQuery插件工具。 1.jQuery Mobile 由于iPhone和BlackBerry移动设备的普及,网络趋向于移动,jQuery Mobile是一个完整的框架,让您轻松地创建移动网站。
1166 0
|
前端开发 UED
前端入门教程(五)CSS样式初见
一 什么是CSS CSS全称Cascading Style Sheet层叠样式表,是专用用来为HTML标签添加样式的。 样式指的是HTML标签的显示效果,比如换行、宽高、颜色等等 层叠属于CSS的三大特性之一,我们将在后续内容中介绍 表指的是我们可以将样式统一收集起来写在一个地方或者一个CSS文件里 二 为何要用CSS 在没有CSS之前,我们想要修改HTML标签的样式则需要为每个HTML标签单独定义样式属性,如下 DOCTYPE html> 天净沙·秋思 锦瑟无端五十弦,一弦一柱思华年。
1119 0
|
JavaScript C# 前端开发