jQuery插件开发结构

开发jQuery插件的方式

可以通过两种方式开发jquery插件

  1. 类级别方式:即给jquery命名空间下添加新的全局函数,也称为静态方法。
  2. 对象级别方式:即挂载在jquery原型下的方法,这样通过选择器选择出来的jquery对象实例也共享该方法,也称为动态方法。
// 1.类级别 
// 例如:$.Ajax() / $.extend()
// jQuery.extend([deep], target, object1, [objectN])
jQuery.pluginname = function() {
    // do something
}

// 2.对象级别 jQuery.extend([deep], target, object1, [objectN])
// 例如:addClass() / attr()等方法,需要实例对象调用
// jQuery.fn.extend(object)
$.fn.pluginname = function() {
    // do something
    // 这里的$.fn === $.prototype
}

自调用匿名函数

通过创建一个自调用匿名函数,创建一个特殊的函数作用域,在该作用域中定义的函数,变量等不会和现有存在的同名函数或变量相冲突。

(function ($){ //这个东西叫做IIFE(自调用函数表达式)
    $.fn.extend({ // 给jquery原型对象扩展方法
        pluginName: function(options){ //插件名字
            // 遍历匹配元素的集合
            return this.each(function(){
                // 在这里写相应的业务
            });
        }
    });
})(jQuery);

插件案例

(function ($){ //这个东西叫做IIFE(自调用函数表达式)
    
    var Plugin = function(){
        
    }
    
    Plugin.prototype = {
        getVersion: function(){
            return "version 0.1";
        }
    }
    
    // 给jquery原型对象扩展方法,通过 $('select').pluginname() 调用
    $.fn.extend({
        //插件名字
        pluginname: function(options){
            var args = [].slice.call(arguments, 1);
          
            // 遍历匹配元素的集合
            return this.each(function(){
                // 单例模式
                var ui = $._data(this, pluginname);
                if(!ui) {
                    // 深拷贝
                    var opts = $.extend(true, {}, $.fn.pluginname.defaults, typeof options === "object" ? options : {});
                    ui = new Plugin(opts, this);
                    $._data(this, pluginname, ui);
                }
                
                if(typeof options === "string" && typeof ui[options] == "function") {
                    ui[options].apply(ui, args); // 执行插件的方法
                }
            });
        }
    });
    
    // 默认配置对象,保证用户在没有传参时情况下也能正常使用插件
    $.fn.pluginname.defaults = {
        
    }
})(jQuery);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • jQuery插件开发模式 软件开发过程中是需要一定的设计模式来指导开发的,有了模式,我们就能更好地组织我们的代码,...
    _双眸阅读 320评论 0 1
  • 第3章 基本概念 3.1 语法 3.2 关键字和保留字 3.3 变量 3.4 数据类型 5种简单数据类型:Unde...
    RickCole阅读 5,149评论 0 21
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,200评论 0 1
  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 1,367评论 0 2
  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 9,285评论 0 3