jquery源码基本结构和插件写法

1. jquery源码基本结构

复制代码
(function(w){
    //工厂
    function jQuery(selector, context){
        //直接返回一个new实例,这样可以隐藏new过程,使用jQuery('#id')创建对象,而不是new jQuery('#id')
        return new jQuery.fn.init(selector, context);
    }
    //给原型提供一个简写方式,jquery.fn等于原型属性这个写法,是最经典的jquery写法
    jQuery.fn = jQuery.prototype = {

    };

    //init才是jQuery中真正的构造函数
    var init = jQuery.fn.init = function(selector, context){

    };
    //把构造函数的原型,替换为jQuery工厂的原型
    //这么做的目的是为了实现jQuery的插件机制,让外界可以通过jQuery方便的进行扩展

    //构造函数的原型 == new出来的这个实例jQuery.fn =  jQuery.prototype 这样就实现了原型继承,可以在$ 对象上面封装自己的方法。
    init.prototype = jQuery.fn;
    w.jQuery = w.$ = jQuery;
}(window));
复制代码

2.jquery的插件写法

jquery.fn代表jquery.prototype,可以在jquery的原型上添加方法。

jquery.extend = jquery.fn.extend;

jquery.extend在jquery上扩展方法,添加全局静态方法。

jquery.fn.extend在jquery实例上扩展方法。

2.1 jquery添加静态方法

$.extend({
    sayHello: function(name) {
        console.log('Hello,' + (name ? name : 'aaa') + '!');
    }
})

$.sayHello('bbb'); //Hello,bbb

2.2 jquery插件定义

$.fn.pluginName = function(){
    //返回一个jquery对象,支持链式调用
    return this.each(function(){
        ...
    })
}

 

posted @   全玉  阅读(207)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2017-05-07 javascript垃圾回收
2017-05-07 javascript作用域链理解
2017-05-07 http状态码
点击右上角即可分享
微信分享提示