jquery编写插件的方法
版权声明:作者原创,转载请注明出处!
编写插件的两种方式:
1.类级别开发插件(1%)
2.对象级别开发(99%)
类级别的静态开发就是给jquery添加静态方法,三种方式
1.添加新的全局函数
2.使用$.extend(obj)
3.使用命名空间
类级别开发插件(用的非常少,1%)
分别举例:
//1.直接给jquer添加全局函数
jQuery.myAlert=function (str) {
alert(str);
}; //2.用extend()方法。extend是jquery提供的一个方法,把多个对象合并起来,参数是object
jQuery.extend({
myAlert2:function (str1) {
alert(str1);
},
myAlert3:function () {
alert(11111);
}
}); //一定要注意两种类级别编写插件方式书写的区别。 //3.使用命名空间(如果不使用命名空间容易和其他引入的JS库里面的同名方法冲突)
jQuery.yuqing={
myAlert4:function (str) {
alert(str);
},
centerWindow:function (obj) {
obj.css({
'top':($(window).height()-obj.height())/2,
'left':($(window).width()-obj.width())/2
});
//必须进行返回对象的操作,否则就不能继续往下进行链式操作了。。
return obj;
}
};
调用部分:
//调用自定义插件方法
$('#btn').click(function () {
$.myAlert('我是调用jquery编写的插件弹出的警告框');
$.myAlert2('我是调用jquery的extend()方法编写的插件弹出的警告框');
$.myAlert3();
$.yuqing.myAlert4("调用使用了命名空间编写的插件方法");
});
$.yuqing.centerWindow($('#div1')).css('background','red');
注意:jquery文件要一并引入。
对象级别开发插件(常用99%)
jquery官方给了一套对象级别开发插件的模板:
;(function ($) {
$.fn.plugin=function (options) {
var defaults={
//各种参数、各种属性
};
//options合并到defaults上,defaults继承了options上的各种属性和方法,将所有的赋值给endOptions
var endOptions=$.extend(defaults,options);
this.each(function () {
//实现功能的代码
});
};
})(jQuery);
模板要点:
1.函数全部放在闭包里,外面的函数就调用不到里面的参数了,比较安全
2.前面加分号,避免不必要的麻烦
举个栗子:
需求:开发一个插件,要求奇数行颜色是yellow,偶数行颜色是green,鼠标移到的行变为blue,移除变为原来的颜色
HTML布局:
<table id="tab">
<tr>
<th>姓名</th>
<th>年龄</th>
<th>身高</th>
<th>体重</th>
</tr>
<tr>
<td>张三</td>
<td>22</td>
<td>178cm</td>
<td>79kg</td>
</tr>
<tr>
<td>美美</td>
<td>34</td>
<td>167cm</td>
<td>60kg</td>
</tr>
<tr>
<td>小青</td>
<td>23</td>
<td>170cm</td>
<td>55kg</td>
</tr>
<tr>
<td>张三</td>
<td>22</td>
<td>178cm</td>
<td>79kg</td>
</tr>
<tr>
<td>美美</td>
<td>34</td>
<td>167cm</td>
<td>60kg</td>
</tr>
<tr>
<td>小青</td>
<td>23</td>
<td>170cm</td>
<td>55kg</td>
</tr>
<tr>
<td>张三</td>
<td>22</td>
<td>178cm</td>
<td>79kg</td>
</tr>
<tr>
<td>美美</td>
<td>34</td>
<td>167cm</td>
<td>60kg</td>
</tr>
<tr>
<td>小青</td>
<td>23</td>
<td>170cm</td>
<td>55kg</td>
</tr>
</table>
css样式
table{
width: 100%;
border-collapse: collapse;
border: 1px solid palevioletred;
}
th,td{
height: 30px;
text-align: center;
border: 1px solid deeppink;
}
.evenRow1{background: yellow;}
.oddRow1{background: green;}
.curRow1{background: blue;}
jquery调用代码:
$('#tab').table({
evenRowClass:'evenRow1',
oddRowClass:'oddRow1',
curRowClass:'curRow1',
eventType1:'click'
});
jquery插件代码:
;(function ($) {
$.fn.table=function (options) {
var defaults={
//各种参数、各种属性
evenRowClass:'evenRow',
oddRowClass:'oddRow',
curRowClass:'curRow',
eventType1:'mouseover',
eventType2:'mouseout'
};
var endOptions=$.extend(defaults,options);
this.each(function () {
var _this = $( this );
_this.find('tr:even').addClass(endOptions.evenRowClass);
_this.find('tr:odd').addClass(endOptions.oddRowClass);
//鼠标移入和移出,但实际开发中不直接使用mouseover这种方法
/*$(this).find('tr').mouseover(function () {
$(this).addClass(endOptions.curRowClass);
}).mouseout(function () {
$(this).removeClass(endOptions.curRowClass);
});*/
//实际开发中要用bian()方法绑定
//因为用bind()方法绑定非常灵活,事件可以自己定义
//mouseover mouseout...事件底层都是用bind()去实现的,mouseout 等只是快捷方式
_this.find('tr').bind(endOptions.eventType1,function () {
$(this).addClass(endOptions.curRowClass);
});
_this.find('tr').bind(endOptions.eventType2,function () {
$(this).removeClass(endOptions.curRowClass);
})
});
};
})(jQuery);
插件注释:
15行:var _this = this; 变量存储,因为很多地方用到$(this);所以将其存储为变量使用更加的方便,也提高了运行效率。
19-23行与28-33行实现的功能是相同的,但是推荐使用28-33行的写法,使用bian()进行事件的绑定,因为使用会非常的灵活。
可变的地方,如样式名称等最好写在defaults里,方便用户自行配置。
再来一个对象级别实现jquery插件的栗子(⊙o⊙)哦!!实现选项卡功能~~
HTML布局
<div id="tab">
<ul id="nav">
<li class="active">HTML</li>
<li>CSS</li>
<li>JAVASCRIPT</li>
</ul>
<div id="cont">
<div style="display: block;">HTML</div>
<div>CSS</div>
<div>JAVASCRIPT</div>
</div>
</div>
css样式:
* {
margin:;
padding:;
}
#nav li {
list-style: none;
float: left;
height: 25px;
line-height: 25px;
border: 1px solid #0000FF;
border-bottom: none;
padding: 5px;
margin: 10px;
margin-bottom:;
}
#cont div {
width: 210px;
height: 150px;
border: 1px solid #0000FF;
margin-left: 10px;
clear: both;
display: none;
}
.active {
background: #AFEEEE;
}
调用的JS代码
<script type="text/javascript">
$('#tab').tab({
tabType: 'mouseover'
});
</script>
注意哦:不要忘记先引入jquery.js文件喔,然后在引入我们编写的插件tab.js,才能正确调用到tab()方法。。。
插件tab.js
;(function($) {
$.fn.tab = function(options) {
var defaults = {
tabActiveClass: 'active',
tabNav: '#nav>li',
tabCont: '#cont>div',
tabType: 'click'
};
var endOptions = $.extend(defaults, options);
$(this).each(function() {
var _this = $(this);
_this.find(endOptions.tabNav).bind(endOptions.tabType, function() {
$(this).addClass(endOptions.tabActiveClass).siblings().removeClass(endOptions.tabActiveClass);
var index = $(this).index();
_this.find(endOptions.tabCont).eq(index).show().siblings().hide();
});
});
};
})(jQuery);
这个小栗子和上一个表格插件的栗子相似度是很高的,多敲几遍,理解意思,其实jquery扩展插件并不难哦~~
如有不对的地方,还请各路大神赐教!
jquery编写插件的方法的更多相关文章
- 再谈:jquery编写插件的方法
版权声明:作者原创,转载请注明出处! 编写插件的两种方式: 1.类级别开发插件(1%) 2.对象级别开发(99%) 类级别的静态开发就是给jquery添加静态方法,三种方式 1.添加新的全局函数 2. ...
- jquery编写插件
jquery编写插件的方法 版权声明:作者原创,转载请注明出处! 编写插件的两种方式: 1.类级别开发插件(1%) 2.对象级别开发(99%) 类级别的静态开发就是给jquery添加静态方法,三 ...
- javascript&&jquery编写插件模板
javascrpt插件编写模板 这里不分享如何编写插件,只留一个框架模板,使用面向对象的形式进行编写,方便管理 ;(function(window,document){ function FnName ...
- 【原】jQuery编写插件
分享一下编写设置和获取颜色的插件,首先我将插件的名字命名为jquery.color.js.该插件用来实现以下两个功能1.设置元素的颜色.2.获取元素的颜色. 先在搭建好如下编写插件的框架: ;(fun ...
- 两个jquery编写插件实例
(1) 封装基于jq弹窗插件 相信码友们对于$.fn.extexd();$.extend()以及$.fn.custom和$.custom都有一定的了解:我阐述一下我自己对于$.fn.custom和 ...
- jquery编写插件(转)
教你开发jQuery插件(转) 阅读目录 基本方法 支持链式调用 让插件接收参数 面向对象的插件开发 关于命名空间 关于变量定义及命名 压缩的好处 工具 GitHub Service Hook 原 ...
- Jquery开发插件的方法
Jquery未开发插件提供了两个方法: (1)Jquery.extend(object) -为Jquery类本身添加新的方法;代码如下: $.extend({ add:function(a,b) ...
- zTree -- jQuery 树插件 使用方法与例子
简介 zTree 是一个依靠 jQuery 实现的多功能 "树插件". 网址:http://www.ztree.me/v3/main.php#_zTreeInfo 上面的网址里有z ...
- 编写基于jQuery的插件的方法
注意:jQuery中有一个extend的方法,这个方法是添加js对象字段的,下面会多次用到 1:添加全局类的方法 常用的ajax就是该类插件,下面要编写一个简单的加法和减法的基于jQuery的方法 $ ...
随机推荐
- VB.NET 创建文件以及文件的读写(创建随机数)
创建文件 Dim strFile As String = String.Format("C:\ErrorLog.txt", DateTime.Today.ToString(&quo ...
- OpenCASCADE View Manipulator
OpenCASCADE View Manipulator eryar@163.com Abstract. When you finish modeling objects in the scene, ...
- 手把手教你用nodejs+SQL Server2012做增删改查
1.开发工具WebStorm 10.0.4 2.打开WebStorm 10.0.4新建项目:
- Android中Bitmap,byte[],Drawable相互转化
一.相关概念 1.Drawable就是一个可画的对象,其可能是一张位图(BitmapDrawable),也可能是一个图形(ShapeDrawable),还有可能是一个图层(LayerDrawable) ...
- geotrellis使用(六)Scala并发(并行)编程
本文主要讲解Scala的并发(并行)编程,那么为什么题目概称geotrellis使用(六)呢,主要因为本系列讲解如何使用Geotrellis,具体前几篇博文已经介绍过了.我觉得干任何一件事情基础很重要 ...
- spring源码分析之cache demo
spring提供了对echache.guava.jcache的支持,先看一个echache的示例: import org.springframework.cache.CacheManager; imp ...
- 自己使用的一个.NET轻量开发结构
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIgAAABFCAIAAAAerjlvAAAE2UlEQVR4nO2a3U/bVhiH+bdyPaqpmx
- Node.js入门初体验
今天有一个类似网络爬虫的需求,本来打算用我还算熟悉的asp或者asp.NET来做这个事情,但是写了这么长时间js,asp的语法实在不喜欢,VS又早被我卸掉了,思来想去打算用一下最近比较火的Node.j ...
- Cesium原理篇:4Web Workers剖析(2)
What's the WebWorkers? 2008 年 W3C 制定出第一个 HTML5 草案中提出了工作线程(Web Worker)的概念,并且规范出 Web Worker 的三大主要特征:能够 ...
- 到处都是坑的微信支付V3
业务需要一个在微信上能付款的功能,于是乎想到了最普遍的支付宝,坑爹的是T与A是水火不容啊,默默的还是接微信支付吧,没想到从此掉进了连环坑…… 网上写微信支付接口的还是很多,PHP官方有(鄙视源码作者, ...