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(){ ... }) }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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状态码