jQuery基础框架浅入剖析 - Web前端
作者:98wpeu发布时间:2026-06-01分类:网页前端技术浏览:72
一、原型模式结构
复制代码 代码如下:
// 定义一个JQuery构造函数
varjQuery = function() {
};
// 扩展jquery原型
jquery.prototype = {
};
上面是一个原型模式结构,一个JQuery构造函数和jQuery实例化对象的的原型对象,我们一般是这样使用的:
复制代码 代码如下:
var jq = new jQuery(); //变量jq通过new关键字实例化jQuery构造函数后就可以使用原型对象中的方法,但是jQuery并不是这么使用的
二、返回选择器实例
复制代码 代码如下:
var jQuery = function() {
// 返回选择器实例
return new jQuery.PRototype.init();
};
jQuery.prototype = {
// 选择器构造函数
init: function() {
}
};
虽然jQuery不是通过new关键字实例化对象,但是执行jQuery函数仍然得到的是一个通过new关键字实例化init选择器的对象,如:
var navCollections = jQuery('.nav'); //变量navCollections保存的是class名为nav的DOM对象集合.
三、访问原型方法
复制代码 代码如下:
var jQuery = function() {
// 返回选择器实例
return new jQuery.prototype.init();
};
jQuery.prototype = {
// 选择器构造函数
init: function() {
},
// 原型方法
toArray: function() {
},
get: function() {
}
};
// 共享原型
jQuery.prototype.init.prototype = jQuery.prototype;
我们一般习惯称jQuery函数中返回的选择器实例对象为jQuery对象,如我们可以这样使用:
复制代码 代码如下:
jQuery.('.nav').toarray(); // 将结果集转换为数组
为什么可以使用toArray方法呢? 即如何让jQuery对象访问jQuery.prototype对象中的方法?只需将实例化选择器对象的原型对象共享jQuery.prototype对象,上面体现代码为:
复制代码 代码如下:
jQuery.prototype.init.prototype = jQuery.prototype; // 共享原型
四、自执行匿名函数
复制代码 代码如下:
(function(window, undefined) {
var jQuery = function() {
// 返回选择器实例
return new jQuery.prototype.init();
};
jQuery.prototype = {
// 选择器构造函数
init: function() {
},
//原型方法
toArray: function() {
},
get: function() {
}
};
jQuery.prototype.init.prototype = jQuery.prototype;
// 局部变量和函数在匿名函数执行完后撤销
var a, b, c;
function fn() {
}
// 使jQuery成为全局变量
window.jQuery = window.$ = jQuery;
})(window);
自执行匿名函数中声明的局部变量和函数在匿名函数执行完毕后撤销,释放内存,对外只保留jQuery全局变量接口。
来源: http://www.cnblogs.com/yangjunhua/archive/2012/12/27/2835989.html
相关推荐
- jQuery中odd选择器的定义和用法 - Web前端
- 您是否深入研究过浏览器缓存的应用? - Web前端
- 常用的jQuery前端技巧收集 - Web前端
- 初学者对于HTML5的一些误解 - Web前端
- 浅析jQuery EasyUI中的tree使用指南 - Web前端
- JQuery中使用.each()遍历元素学习笔记 - Web前端
- c#+JQurey实现获取radio和checkbox的值 - Web前端
- 使用ajax+jqtransform实现动态加载select - Web前端
- 如何在MVC应用程序中使用Jquery - Web前端
- 深入分析JQuery和JavaScript的异同 - Web前端
- 网页前端技术排行
-
- 1【第六章】Foundation之按钮和下拉功能 - Web前端
- 2jQuery编写widget的一些技巧分享 - Web前端
- 3基于jquery的滚动条滚动固定div(附演示下载) - Web前端
- 4jQuery实例教程:制作网页中可折叠的面板 - Web前端
- 5在Mac/PC上远程调试iPhone/iPad上的网页 - Web前端
- 6分析Iconfont-阿里巴巴矢量常用图标库 - Web前端
- 7JS网页制作实例:标签云 - Web前端
- 8[Web前端]用javascript实现默认图片替代未显示的图片 - Web前端
- 9分享精心挑选的12款优秀jQuery Ajax分页插件和教程 - Web前端
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


