jQuery 插件基础
jQuery 插件基础
如果你需要在 jQuery 选择器上执行一系列重复操作, 这时候你需要编写 jQuery 插件.
jQuery 对象方法
在开始编写插件前, 首先需要了解 jQuery 原理. 请看下面的代码:
$( "a" ).css( "color", "red" );
这是一段非常简单的 jQuery 代码, 但是你知道这背后发生了什么? 当你使用 $
函数选择元素时, 它返回 jQuery 对象. 你可以在这个对象上调用各种方法 (比如 .css(), .click()
等). 这些 jQuery 方法通过 $.fn
原型继承. 我们可以通过在 $.fn
上添加属性, 就可以调用自己的方法.
一个简单的插件
本小节我们通过创建一个使所有元素变绿的插件来了解如何创建 jQuery 插件. 通过在 $.fn
上添加 greenify
方法来实现:
$.fn.greenify = function() {
this.css('color', 'green');
};
$('a').greenify();
可以在 greenify
看到我们通过 this
来调用 .css
, 而不是 $(this)
, 这是因为我们的 greenify
函数已经是和 .css()
一样, 都是 jQuery 对象的方法.
链式调用
我们可以在插件函数中返回 this
来实现链式调用:
$.fn.greenify = function() {
this.css('color', 'green');
return this;
};
$('a').greenify().addClass('greenified');
$
变量和作用域
通常我们使用 jQuery 的别名 $
变量来使用 jQuery, 如果你使用 jQuery 以外的库中也使用了 $
变量, 你需要调用 jQuery.noConflict()
使 jQuery 不使用 $
. 但是在我们的插件代码中不能生效, 因为我们直接使用 $
变量作为 jQuery 的别名. 为了更通用化, 并且依旧使用 $
别名, 将我们的代码包裹在立即函数调用中, 并且传递 jQuery:
(function($){
$.fn.greenify = function() {
this.css('color', 'green');
return this;
};
})(jQuery);
减少插件数目
在实现 jQuery 插件时, 应该减少挂载在 $.fn
上的插件. 这能减少插件相互覆盖的情况. 下面是一个不推荐的用法:
(function($){
$.fn.openPopup = function() {
// Open popup code.
};
$.fn.closePopup = function() {
// Close popup code.
};
})(jQuery);
推荐的做法是: 使用一个插件, 通过参数来执行不同操作:
(function( $ ) {
$.fn.popup = function( action ) {
if ( action === "open") {
// Open popup code.
}
if ( action === "close" ) {
// Close popup code.
}
};
}( jQuery ));
each
方法
通常使用 jQuery 选择器都返回 DOM
元素的集合, 如果插件是在特定元素上执行, 比如获取数据, 元素位置等操作, 就需要使用 each
方法, 这能保证我们的代码对每个元素都起作用:
$.fn.rectify = function() {
return this.each(function() {
var width = $(this).css('width');
this.css('height', width)
});
};
上述的代码使 DOM
对象高和宽相同, 如果不使用 each
, 那么就只对第一个对象起作用.
因为 each
本身就是链式调用, 所以我们直接返回 each
的结果.
插件添加选项参数
当插件越来越复杂的时候, 可以为插件添加选项参数:
(function ( $ ) {
$.fn.colorfy = function( options ) {
// This is the easiest way to have default options.
var settings = $.extend({
// These are the defaults.
color: "#556b2f",
backgroundColor: "white"
}, options );
// Greenify the collection based on the settings variable.
return this.css({
color: settings.color,
backgroundColor: settings.backgroundColor
});
};
}( jQuery ));
$( "div" ).colorfy({
color: "orange"
});
例子
一些 jQuery 插件的例子
https://445141126.github.io/jquery-demo/
jQuery 插件基础的更多相关文章
- js最详细的基础,jquery 插件最全的教材
一.Js的this,{},[] this是Javascript语言的一个关键字,随着函数使用场合的不同,this的值会发生变化.但是有一个总的原则,那就是this指的是调用的函数自己. { } 大括号 ...
- 【jQuery基础学习】08 编写自定义jQuery插件
目的:虽然jQuery各种各样的功能已经很完善了,但是我们还是要学会自己去编写插件.这样我们可以去封装一些项目中经常用到的专属的代码,以便后期维护和提高开发效率. jQuery插件的类型: 封装对象方 ...
- 前端基础进阶(十一):详细图解jQuery对象,以及如何扩展jQuery插件
早几年学习前端,大家都非常热衷于研究jQuery源码.我还记得当初从jQuery源码中学到一星半点应用技巧的时候常会有一种发自内心的惊叹,“原来JavaScript居然可以这样用!” 虽然随着前端的发 ...
- 关于jQuery插件imgAreaSelect基础讲解
关于ImgAreaSelect, 是一jQuery插件,它支持用户通过鼠标拖曳选择图片的一部分,如图片拖曳.图片编辑等~~来具体看一下 1.先下载imgAreaSelect插件 下载地址: 英文:h ...
- 自己写jquery插件之模版插件高级篇(一)
需求场景 最近项目改版中,发现很多地方有这样一个操作(见下图gif动画演示),很多地方都有用到.这里不讨论它的用户体验怎么样. 仅仅是从复用的角度,如果每个页面都去写text和select元素,两个b ...
- JS原生ajax与Jquery插件ajax深入学习
序言: 近来随着项目的上线实施,稍微有点空闲,闲暇之时偶然发现之前写的关于javascript原生xmlHttpRequest ajax方法以及后来jquery插件ajax方法,于是就行了一些总结,因 ...
- jquery插件的两种形式
这里总结一下jquery插件的两种形式,一种是通过字面量的形式组织代码,另一种是通过构造函数的方式.下面就两种形式来分析俩个例子. 例子1: ;(function ($,window,document ...
- JQuery插件之Jquery.datatables.js用法及api
1.DataTables的默认配置 $(document).ready(function() { $('#example').dataTable(); } ); 示例:http://www.guoxk ...
- jquery插件 - 学习笔记 (插件参数及函数的调用)
今天研究的是jquery插件的基本写法: 比如我打算写一个名为 ImageZoom 的插件 前台调用: <script src="ImageZoom.js"></ ...
随机推荐
- Linux软raid创建
RAID: HBA:基于主机的适配器 RAID:Redundent Array of Inexpensive Disks 廉价磁盘阵列 Independent 独立磁盘阵列 Level:仅 ...
- nginx入门篇----安装、部署、升级
1.安装前准备工作下载nginx安装包依赖包:gcc pcre pcre-level zlib zlib-devel openssl openss-level在线依赖包安装命令:yum -y ins ...
- 经验分享:Linux 双网卡SNAT和DNAT映射本地端口出外网
A 机器 网卡1 公网IP网卡2 内网 B 机器网卡1 内网 如果想把公网端口P1 映射为内网B机器端口P2 iptables -t nat -A PREROUTING -d [A公网地址] -p ...
- MYCAT介绍(转)
从定义和分类来看,它是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个M ...
- 【转】关于启用 HTTPS 的一些经验分享
随着国内网络环境的持续恶化,各种篡改和劫持层出不穷,越来越多的网站选择了全站 HTTPS.HTTPS 通过 TLS 层和证书机制提供了内容加密.身份认证和数据完整性三大功能,可以有效防止数据被查看或篡 ...
- React组件生命周期过程说明
来自kiinlam github94 实例化 首次实例化 getDefaultProps getInitialState componentWillMount render componentDidM ...
- AngularJs之$scope对象(作用域)
一.作用域 AngularJs中的$scope对象是模板的域模型,也称为作用域实例.通过为其属性赋值,可以传递数据给模板渲染. 每个$scope都是Scope类的实例,Scope类有很多方法,用于 ...
- Android学习笔记(十)
Android控件——ListView ListView允许用户通过手指上下滑动的方式将屏幕外的数据滚动到屏幕内,同时 屏幕上原有的数据则会滚动出屏幕. 1.ListView的简单用法 新建一个Lis ...
- SQL数据库添加新账号,只操作指定数据库
思路: 1.创建数据库服务器登录用户 2.创建指定数据库的用户,并且和服务器用户联系起来 3.给数据库的用户添加角色 代码实现: 1.创建名为login的服务器登录用户dba,尼玛dbpwd,默认数据 ...
- Docker 的 Image 太大,怎么变小?
铛~铛~铛~Docker即将颠覆整个软件产业,从云计算平台到软件开发.测试,整个SDLC都会极度依赖Docker. 圈子里面一定有很多讨论Docker的话题,简而言之,Docker其实只解决一个问题: ...