点击打开:

jquery系列教程1-选择器全解

jquery系列教程2-style样式操作全解

jquery系列教程3-DOM操作全解

jquery系列教程4-事件操作全解

jquery系列教程5-动画操作全解

jquery系列教程6-ajax的应用全解

jquery系列教程7-自定义jquery插件全解

jquery系列教程8-jquery插件大全

自定义jquery插件详解:

1、插件名称最好为jquery.[插件名].js。所有方法和函数插件都应该以分号结尾。插件开头也应该添加分号。

2、插件应该返回一个jquery对象,以保证链式操作。或者返回需要获取的量。插件内部不要使用$作为jquery对象的别名。

3、所有的对象方法附加到jQuery.fn对象上,所有的全局函数,附加到jQuery对象上。

4、插件内部,this指向通过选择器获取的jquery对象,可以通过this.each遍历所有元素。

5、基本定义方法

;(function($){                                                  //最前端的分号为了更好的兼容性,  将$作为匿名函数的形参
    //此处编写jquery插件代码,可以将$作为jquery的缩写别名
})(jQuery);                                                     //这里就将jquery作为实参传递给匿名函数

6、基本扩展方法

options = jQuery.extend({                                       //extend扩展对象属性,extent收集多个对象参数的属性集合,属性的值以最晚出现的为准
    name:"name1",                                               //既可以用于为对象设置属性默认值,又可以用来扩展对象
    age:12
},options);                                                     //当oprions属性和默认属性重叠时,值以越晚出现的为准

封装jquery对象函数

;(function($){
    $.fn.extend({                                                //对jquery.fn对象进行扩展
        "color":function(value){                                //自定义color函数,设置无参和有参时的调用
            if(value==undefined)
                return this.css("color");                       //没有参数时返回颜色   this表示jquery选择器选择的元素对象
            else
                return this.css("color",value);                 //有参数时设置颜色
        },
        "myfun": function (options) {                           //多个自定函数,以映射的形式存在于一个字典中
            options = $.extend({name:"name1",age:12},options);   //对传递参数可能不全的情况进行兼容,设置默认值
            //使用options进行后续函数
            return this;                                         //返回this,使方法可链
        },
        "max":function(){                                        //选择器选择的元素可能有多个,通过this传递过来就是元素列表
            return this.each(function () {                      //通过each对选择的元素列表进行遍历

            });
        }
    });
})(jQuery);

调用对象函数

$("div").color("red");                                          //设置颜色

封装jquery全局函数

;(function($){
    $.extend({                                                  //全部函数,不需要fn,对jquery自己进行扩展
        myfun1:function(text){
            return text;
        },
        myfun2:function(value){}
    });
})(jQuery);

调用全局函数

jQuery.myfun1("111111");

自定义jquery选择器

;(function($) {
    $.extend(jQuery.expr[":"],{                             //自定义选择器是jQuery.expr[":"]对象的一部分,所以对该对象进行扩展
        between:  function(a,i,m){                           //自定义between选择器,  a表示遍历到的当前DOM元素,i表示DOM元素的索引,从0开始,m是一个数组。
            //以$("div:gt(1)")为例。m[0]表示进一步要匹配的内容:gt(1)    m[1]表示选择器引导符:    m[2]表示选择器函数get     m[3]表示选择器函数参数1
            var tmp=m[3].split(",");                        //以逗号为分隔符,这里自己定义分隔符
            return tmp[0]-0<i && i<tmp[1]-0;                //当元素索引在两个参数之间,返回true,表示选中
        }
    });
})(jQuery);

应用自定义选择器

$("div:between(2,5)").css("color","red");

jquery系列教程7-自定义jquery插件全解:对象函数、全局函数、选择器的更多相关文章

  1. jquery系列教程4-事件操作全解

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  2. jquery系列教程2-style样式操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  3. jquery系列教程6-ajax的应用全解

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  4. jquery系列教程3-DOM操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  5. jquery系列教程1-选择器全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...

  6. Spring 系列教程之自定义标签的解析

    Spring 系列教程之自定义标签的解析 在之前的章节中,我们提到了在 Spring 中存在默认标签与自定义标签两种,而在上一章节中我们分析了 Spring 中对默认标签的解析过程,相信大家一定已经有 ...

  7. React Native实战系列教程之自定义原生UI组件和VideoView视频播放器开发

    React Native实战系列教程之自定义原生UI组件和VideoView视频播放器开发   2016/09/23 |  React Native技术文章 |  Sky丶清|  4 条评论 |  1 ...

  8. Sql Server函数全解<五>之系统函数

    原文:Sql Server函数全解<五>之系统函数  系统信息包括当前使用的数据库名称,主机名,系统错误消息以及用户名称等内容.使用SQL SERVER中的系统函数可以在需要的时候获取这些 ...

  9. Jquery系列教程

    最近想重新温习下Jquery,发现园子里有个很棒的系列教材,所以Mark下来. 转载自:http://www.cnblogs.com/zhangziqiu/tag/jQuery%E6%95%99%E7 ...

随机推荐

  1. 201521123013 《Java程序设计》第4周学习总结

    1. 本章学习总结 1.1 尝试使用思维导图总结有关继承的知识点. 1.2 使用常规方法总结其他上课内容. 1.多态是面向对象的三大特性之一.多态的意思:相同的形态,可以实不同的行为.Java中实现多 ...

  2. 201521123106《java程序设计》第二周学习总结

    1. 本周学习总结 学习了java的基础语法.在java中使用浮点型会不精确,改用double行就好.学习了string的类型,string的对象是不可变的,创建之后不能再修改,在string的拼接中 ...

  3. Win8打开chm右侧空白解决方法

    Win8下打开CHM文件,左侧有目录,但是右侧空白.而且打开的时候,还弹出很多IE窗口. 感觉应该不是文件本身的问题.下面是我的解决方法,其他系统也可以试一试. 最初打开文件如下 首先:1,右键关联c ...

  4. 201521123077 《Java程序设计》第13周学习总结

    1. 本周学习总结 1.1以你喜欢的方式(思维导图.OneNote或其他)归纳总结多网络相关内容. 介绍的传输层协议 : TCP 可靠:具有失败重传功能 开销较大:需要建立链路 需要维持传输中的关系 ...

  5. 06jQuery-04-DOM操作

    jQuery既然是为了帮助你能从js的繁琐中解脱出来,自然在DOM操作上也有自己的一套. 1.修改Text和HTML 之前我们提到过,如果用JS的话,你要修改Text或者HTML需要用到其innerH ...

  6. 如何延长IntelliJ IDEA的试用期?

    想打开idea写个代码...提示idea快过期...不开森...然鹅.   根据网上各种说明,总结大体分为以下4种方法: 方法1.直接输入激活码Activation Code(亲自验证有效而且非常简单 ...

  7. Activiti-01

    1, Activiti官网:http://www.activiti.org/  主页可以看到jar包的下载. 2, 进入http://www.activiti.org/userguide/index. ...

  8. [python学习笔记] 运算符

    数学运算符 与大多语言相同的运算符就不介绍了.不同的地方会用 (!不同)标出 与java相同的运算符 , - , * , % , / 不同之处 除法 (!不同) /  与java不同,整数相除,结果为 ...

  9. Jquery一些常用的方法

    整理以前的笔记,在学习JavaScript时候,经常会用到一些方法,但是有时忘掉了具体用法,因此记下.方便以后查阅. 这篇博文先说明这些方法的用途: removeClass().remove().cs ...

  10. js'初学笔记

    之前看过一个博主说的学习前端养成写博客的习惯,我慢慢学着在上面写点东西,记录我的学习. 这段时间把之前学的js基础补上一点,学了一些对数组和字符的操作,split(),将字符串变成数组.join(), ...