jQuery插件开发初探
最简单的插件
$.fn.changeStyle = function (colorStr) {
$(this).css('color',colorStr);
}
应用如下:
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle('red');
</script>
</html>

但是如果想连续使用,就不好用了,比如:
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle('red').css('font-size','20px');
</script>
</html>
这里的设置字体大小就没有效果了。
需要简单处理一下上面的拓展程序。
$.fn.changeStyle = function (colorStr) {
this.css('color',colorStr);
return this;
}
加上return this;就可以了。
进一步扩展
(function ($) {
$.fn.changeStyle = function (colorStr) {
this.css('color',colorStr);
return this;
}
}(jQuery));
这样处理会更加安全,防止被污染
支持更多参数
(function ($) {
$.fn.changeStyle = function (colorStr,fontSize) {
this.css('color',colorStr).css('font-size',fontSize);
return this;
}
}(jQuery));
这里传递了两个参数
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle('red','25px');
</script>
</html>
灵活处理参数
(function ($) {
$.fn.changeStyle = function (option) {
this.css('color',option.colorStr).css('font-size',option.fontSize);
return this;
}
}(jQuery));
这里用json对象传递参数,更加灵活。
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle({colorStr:'red',fontSize:'25px'});
</script>
</html>
支持默认参数处理
(function ($) {
$.fn.changeStyle = function (option) {
var defaultSetting = {colorStr:'blue',fontSize:'12px'};
var setting = $.extend(defaultSetting,option);
this.css('color',setting.colorStr).css('font-size',setting.fontSize);
return this;
}
}(jQuery));
这里会合并给定的参数和默认的参数,
如果只传一个参数,就会启用默认的参数。
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle({fontSize:'25px'});
</script>
</html>

后记
也可以这样处理
(function ($) {
$.fn.extend({
changeStyle:function (option) {
var defaultSetting = {colorStr:'blue',fontSize:'12px'};
var setting = $.extend(defaultSetting,option);
this.css('color',setting.colorStr).css('font-size',setting.fontSize);
return this;
}
});
}(jQuery));
$.fn $.fn.extend $.extend 的理解
(function ($) {
$.fn.extend({
changeStyle: function (option) {
var defaultSetting = {colorStr: 'blue', fontSize: '12px'};
var setting = $.extend(defaultSetting, option);
this.css('color', setting.colorStr).css('font-size', setting.fontSize);
return this;
}
});
// 静态方法,直接通过$调用,不可以通过元素调用
$.extend({
min: function (a, b) {
return a < b ? a : b;
},
max: function (a, b) {
return a > b ? a : b;
}
});
// 可以通过元素调用
$.fn.extend({
min: function (a, b) {
return a < b ? a : b;
},
max: function (a, b) {
return a > b ? a : b;
}
});
}(jQuery));
调用如下,
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jquery插件开发</title>
</head>
<body>
<p>Hello jQuery!</p>
</body>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.extend.js"></script>
<script type="text/javascript">
$('p').changeStyle({fontSize:'25px'});
$.min('3','5'); // 3
$('p').min('3','5'); // 3
</script>
</html>
1. $.fn 和 $.fn.extend 都是针对成员进行扩展的,$.extend扩展的是静态方法。
2. jQuery.fn.extend拓展的方法,你得用在jQuery对象上面才行啊!
3. jQuery.extend(),是扩展的jQuery这个类。
jQuery插件开发初探的更多相关文章
- JQuery插件开发初探——图片轮播
在熟悉了插件开发的结构以后,自己尝试着做了一个稍微复杂一点的小功能:图片轮播插件. 由于之前使用的一款图片轮播插件,性能不高,页面加载的时候需要载入全部的图片,因此速度很慢. 通过自己做这个小插件,能 ...
- JQuery插件开发初探——结构熟悉
工作之余,对Jquery插件做了一点尝试,想着之前总用别人写的插件,自己要是也写一个用岂不是很cool.于是说干就干,动手开始写. 首先是模仿,从一个简单的功能进行入手,了解一下插件开发的流程和结构. ...
- JavaScript学习笔记(四)——jQuery插件开发与发布
jQuery插件就是以jQuery库为基础衍生出来的库,jQuery插件的好处是封装功能,提高了代码的复用性,加快了开发速度,现在网络上开源的jQuery插件非常多,随着版本的不停迭代越来越稳定好用, ...
- JavaScript学习总结(四)——jQuery插件开发与发布
jQuery插件就是以jQuery库为基础衍生出来的库,jQuery插件的好处是封装功能,提高了代码的复用性,加快了开发速度,现在网络上开源的jQuery插件非常多,随着版本的不停迭代越来越稳定好用, ...
- jQuery插件开发精品教程,让你的jQuery提升一个台阶
要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈 ...
- jquery插件开发
jQuery是一个封装的很好的类,比如我们用语句$("#btn1") 会生成一个 jQuery类的实例. 一.jQuery插件开发注意要点 1.使用闭包,避免全局依赖,避免第三方破 ...
- jQuery插件开发(溢出滚动)
声明:此程序仅针对手机端,简单的封装一个插件,意在记载插件的开发过程,如有错误及不足之处,还望即时指出. 移动开发的时候,我们经常会遇到滑动事件,众所周知手机端滑动主要依靠touch事件.最近接连遇到 ...
- 从零开始学jQuery插件开发
http://www.w3cfuns.com/notes/19462/ec18ab496b4c992c437977575b12736c.html jQuery 最成功的地方,是它的可扩展性,通过吸引了 ...
- jquery插件开发继承了jQuery高级编程思路
要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈 ...
随机推荐
- (WC2018模拟十二)【FJOI2016集训Day7T1】挑选子序列
题解: 这题太神仙了,先咕着,放个令人****的官方题解(精确覆盖问题是NP完全问题啊摔) Dancing Link X学习资料:QAQ TAT qwq Orz Donald Knuth大神... p ...
- JS脚本代替人工输入
最近接到了个任务,对某个网页上的1000个item填写相同的text,text的内容相同. 这显然是机械动作呀,干脆写个工具,用脚本代替人工操作. 浏览器按F12,找到console,输入写好的脚本, ...
- ansible搭建mysql主主模式
ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)等优点,实现了批量系统配置.批量程序部署.批量运行命 ...
- camke 参数
cmake -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 \ -DMYSQL_DATADIR=/application/mysql-5.5.32 ...
- 紫书 例题11-7 UVa 753 (网络流最大流)
设一个源点, 到所有设备连一条弧, 容量为1, 然后设一个汇点, 所有插座到汇点连弧, 容量为1, 然后 转换器也连一条弧, 容量为1. 最后最大流就是答案.其中注意节点数要开大一些. #includ ...
- 【codeforces 466D】Increase Sequence
[题目链接]:http://codeforces.com/problemset/problem/466/D [题意] 给你n个数字; 让你选择若干个区间; 且这些区间[li,ri]; 左端点不能一样; ...
- C#获取本机内网外网IP
using System.Net; # region 获取内.外网Ip /// <summary> /// 获取本地ip地址,优先取内网ip /// </summary> pu ...
- hdoj 1719 Friend
Friend Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- caffe for python (官方翻译)
导言 本教程中,我们将会利用Caffe官方提供的深度模型——CaffeNet(该模型是基于Krizhevsky等人的模型的)来演示图像识别与分类.我们将分别用CPU和GPU来进行演示,并对比其性能.然 ...
- NOIP 2017 逛公园 记忆化搜索 最短路 好题
题目描述: 策策同学特别喜欢逛公园.公园可以看成一张N个点MM条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值, 代表策策经过这条边所要花的时间. ...