jQuery插件的写法分享


Posted in Javascript onJune 12, 2013

1、概述

先看看html代码

<ul id="catagory">
    <li><a href="#">jQuery</a></li>
    <li><a href="#">Asp.net</a></li>
    <li><a href="#">Sql Server</a></li>
    <li><a href="#">CSS</a></li>
</ul>

比如我们要实现当光标移动到a标签上时,a标签向右移动一段距离,离开时a位置恢复。实现方法如下:

$(document).ready(function() {
    $("#catagory a").hover(function() {
        $(this).animate({ paddingLeft: "20px" }, { queue: false, duration: 500 });
    }, function() {
        $(this).animate({ paddingLeft: "0" }, { queue: true, duration: 500 });
    });
});

现在我们将这个方法进行扩展,写成jQuery插件的形式,以后也能在别的项目中使用,并且可以方便的更改一些属性值,现在我们来看看jQuery插件的写法。

2、jQuery插件的结构

下边这个结构应该是编写jQuery插件的一个比较好的结构,我将原作者的一些注释进行了相应的翻译。

//为避免冲突,将我们的方法用一个匿名方法包裹起来
(function($) {
    //扩展这个方法到jquery
    $.fn.extend({
        //插件名字
        pluginname: function() {
            //遍历匹配元素的集合
            return this.each(function() {
                //在这里编写相应代码进行处理 
            });
        }
    });
 //传递jQuery到方法中,这样我们可以使用任何javascript中的变量来代替"$"      
})(jQuery);

接下来,我们给插件中加入一些可以改变的属性,这样用户可以根据自己的需要来做一些更改。同时,我们应提供相应的默认值。

(function($){  
    $.fn.extend({   
 //将可选择的变量传递给方法
        pluginname: function(options) {  
            //设置默认值并用逗号隔开
            var defaults = {  
                padding: 20,  
                mouseOverColor : '#000000',  
                mouseOutColor : '#ffffff'  
            }  
            var options =  $.extend(defaults, options);  
            return this.each(function() {  
                var o = options;  
                //这里编写相应代码 
                //可以像下边这样获取变量值 
                alert(o.padding);  
            });  
        }  
    });  
})(jQuery); 

3、实现jQuery插件

(function ($) {
    $.fn.extend({
        //插件名称 - paddingList
        paddingList: function (options) {
            //参数和默认值
            var defaults = {
                animatePadding: 10,
                hoverColor: "Black"
            };
            var options = $.extend(defaults, options);
            return this.each(function () {
                var o = options;
                //将元素集合赋给变量 本例中是 ul对象 
                var obj = $(this);
                //得到ul中的a对象
                var items = $("li a", obj);
                //添加hover()事件到a
                items.hover(function () {
                    $(this).css("color", o.hoverColor);
                    //queue false表示不添加到动画队列中
                    $(this).animate({ paddingLeft: o.animatePadding }, { queue: false, duration: 300 });
                }, function () {
                    $(this).css("color", "");
                    $(this).animate({ paddingLeft: "0" }, { queue: true, duration: 300 });
                });
            });
        }
    });
})(jQuery);

最后,使用插件的方法如下:

//使用插件
$(document).ready(function() {
    $("#catagory").paddingList({ animatePadding: 30, hoverColor: "Red" });
});
作者:朋友的你 来源:jQuery学习
Javascript 相关文章推荐
你可能不再需要JQUERY
Mar 09 Javascript
javascript web页面刷新的方法收集
Jul 02 Javascript
ExtJs grid行 右键菜单的两种方法
Jun 19 Javascript
node.js中的fs.fchmodSync方法使用说明
Dec 16 Javascript
JavaScript将字符串转换成字符编码列表的方法
Mar 19 Javascript
javascript设置和获取cookie的方法实例详解
Jan 05 Javascript
微信小程序 loading 详解及实例代码
Nov 09 Javascript
angular.JS实现网页禁用调试、复制和剪切
Mar 31 Javascript
Express进阶之log4js实用入门指南
Feb 10 Javascript
微信小程序版本自动更新的方法
Jun 14 Javascript
jQuery 移除事件的方法
Jun 20 jQuery
jquery插件懒加载的示例
Oct 24 jQuery
jQuery 淡出一个图像到另一个图像的实现代码
Jun 12 #Javascript
单击浏览器右上角的X关闭窗口弹出提示的小例子
Jun 12 #Javascript
Jquery 表单验证类介绍与实例
Jun 09 #Javascript
js调用后台servlet方法实例
Jun 09 #Javascript
Jquery实现列表(隔行换色,全选,鼠标滑过当前行)效果实例
Jun 09 #Javascript
Jquery加载时从后台读取数据绑定到dropdownList实例
Jun 09 #Javascript
ScrollDown的基本操作示例
Jun 09 #Javascript
You might like
PHP遍历二维数组的代码
2011/04/22 PHP
CentOS6.5 编译安装lnmp环境
2014/12/21 PHP
高质量PHP代码的50个实用技巧必备(上)
2016/01/22 PHP
数组任意位置插入元素,删除特定元素的实例
2017/03/02 PHP
PHP的简单跳转提示的实现详解
2019/03/14 PHP
Laravel中validation验证 返回中文提示 全局设置的方法
2019/09/29 PHP
Laravel框架Eloquent ORM简介、模型建立及查询数据操作详解
2019/12/04 PHP
谈谈javascript中使用连等赋值操作带来的问题
2015/11/26 Javascript
前端微信支付js代码
2016/07/25 Javascript
jQuery实现智能判断固定导航条或侧边栏的方法
2016/09/04 Javascript
js实现文字无缝向上滚动
2017/02/16 Javascript
基于bootstrap实现bootstrap中文网巨幕效果
2017/05/02 Javascript
Vue中的无限加载vue-infinite-loading的方法
2018/04/08 Javascript
vue组件详解之使用slot分发内容
2018/04/09 Javascript
快速解决vue-cli在ie9+中无效的问题
2018/09/04 Javascript
JS获取当前时间的实例代码(昨天、今天、明天)
2018/11/13 Javascript
详解JavaScript之ES5的继承
2020/07/08 Javascript
python自动发邮件库yagmail的示例代码
2018/02/23 Python
使用Python搭建虚拟环境的配置方法
2018/02/28 Python
TensorFlow实现卷积神经网络
2018/05/24 Python
用xpath获取指定标签下的所有text的实例
2019/01/02 Python
python pandas写入excel文件的方法示例
2019/06/25 Python
Python 没有main函数的原因
2020/07/10 Python
Python二元算术运算常用方法解析
2020/09/15 Python
video.js支持m3u8格式直播的实现示例
2020/05/20 HTML / CSS
Java程序员面试题
2016/09/27 面试题
竞职演讲稿范文
2014/01/11 职场文书
JAVA程序员自荐书
2014/01/30 职场文书
大二自我鉴定
2014/01/31 职场文书
2014年社区矫正工作总结
2014/11/18 职场文书
学生考试舞弊检讨书
2015/01/01 职场文书
中英文求职信范文
2015/03/19 职场文书
羊脂球读书笔记
2015/06/30 职场文书
初中化学教学反思
2016/02/22 职场文书
导游词之宿迁乾隆行宫
2019/10/15 职场文书
js判断两个数组相等的5种方法
2022/05/06 Javascript