jQuery基础框架浅入剖析 - Web前端
作者:98wpeu发布时间:2026-06-01分类:网页前端技术浏览:3
一、原型模式结构
复制代码 代码如下:
// 定义一个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实现原理介绍) - Web前端
- 下一篇:已经是最后一篇了
相关推荐
- jQuery滚动加载图片效果的实现 - Web前端
- 表头固定(利用jquery实现原理介绍) - Web前端
- 用JQuery在网页中实现分隔条功能的代码 - Web前端
- jquery入门—编写一个导航条(可伸缩) - Web前端
- 超级有用的13个基于jQuery的内容滚动插件和教程 - Web前端
- jquery(javascript)自动序列编号和属性编号实现代码 - Web前端
- 基于jquery完美拖拽,可返回拖动轨迹 - Web前端
- 基于jquery的不规则矩形的排列实现代码 - Web前端
- 仿百度的关键词匹配搜索示例 - Web前端
- 超级有用的13个基于jQuery的内容滚动插件和教程 - 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属性


