jQuery源码分析-extend函数

准备将jQuery、Ext等框架源码仔细分析一遍,并将结果发出来供大家学习、讨论。
这是我的处女贴,请大家多多关照! :)


/*!
* jQuery源码分析-extend函数
* jQuery版本:1.4.2
*
* ----------------------------------------------------------
* 函数介绍
* jQuery.extend与jQuery.fn.extend指向同一个函数对象
* jQuery.extend是jQuery的属性函数(静态方法)
* jQuery.fn.extend是jQuery函数所构造对象的属性函数(对象方法)
*
* ----------------------------------------------------------
* 使用说明
* extend函数根据参数和调用者实现功能如下:
* 1.对象合并:
* 对象合并不区分调用者,jQuery.extend与jQuery.fn.extend完全一致
* 也就是说对jQuery对象本身及jQuery所构造的对象没有影响
* 对象合并根据参数区分,参数中必须包括两个或两个以上对象
* 如:$.extend({Object}, {Object}) 或 $.extend({Boolean},{Object}, {Object})
* 对象合并返回最终合并后的对象,支持深度拷贝
*
* 2.为jQuery对象本身增加方法:
* 这种方式从调用者和参数进行区分
* 形式为 $.extend({Object})
* 这种方式等同于 jQuery.{Fnction Name}
*
* 3.原型继承:
* 原型继承方式可以为jQuery所构造的对象增加方法
* 这种方式也通过调用者和参数进行区分
* 形式为 $.fn.extend({Object})
* 这种方式实际上是将{Object}追加到jQuery.prototype,实现原型继承
*
* ----------------------------------------------------------
*
*/

// jQuery.fn = jQuery.prototype
// jQuery.fn.extend = jQuery.prototype.extend
jQuery.extend = jQuery.fn.extend = function(){

//目标对象
var target = arguments[0] || {},

//循环变量,它会在循环时指向需要复制的第一个对象的位置,默认为1
//如果需要进行深度复制,则它指向的位置为2
i = 1,

//实参长度
length = arguments.length,

//是否进行深度拷贝
//深度拷贝情况下,会对对象更深层次的属性对象进行合并和覆盖
deep = false,

//用于在复制时记录参数对象
options,

//用于在复制时记录对象属性名
name,

//用于在复制时记录目标对象的属性值
src,

//用于在复制时记录参数对象的属性值
copy;

//只有当第一个实参为true时,即需要进行深度拷贝时,执行以下分支
if (typeof target === "boolean") {
//deep = true,进行深度拷贝
deep = target;

//进行深度拷贝时目标对象为第二个实参,如果没有则默认为空对象
target = arguments[1] || {};

//因为有了deep深度复制参数,因此i指向的位置为第二个参数
i = 2;
}

//当目标对象不是一个Object且不是一个Function时(函数也是对象,因此使用jQuery.isFunction进行检查)
if (typeof target !== "object" && !jQuery.isFunction(target)) {

//设置目标为空对象
target = {};
}

//如果当前参数中只包含一个{Object}
//如 $.extend({Object}) 或 $.extend({Boolean}, {Object})
//则将该对象中的属性拷贝到当前jQuery对象或实例中
//此情况下deep深度复制仍然有效
if (length === i) {

//target = this;这句代码是整个extend函数的核心
//在这里目标对象被更改,这里的this指向调用者
//在 $.extend()方式中表示jQuery对象本身
//在 $.fn.extend()方式中表示jQuery函数所构造的对象(即jQuery类的实例)
target = this;

//自减1,便于在后面的拷贝循环中,可以指向需要复制的对象
--i;
}

//循环实参,循环从第1个参数开始,如果是深度复制,则从第2个参数开始
for (; i < length; i++) {

//当前参数不为null,undefined,0,false,空字符串时
//options表示当前参数对象
if ((options = arguments[i]) != null) {

//遍历当前参数对象的属性,属性名记录到name
for (name in options) {

//src用于记录目标对象中的当前属性值
src = target[name];

//copy用于记录参数对象中的当前属性值
copy = options[name];

//存在目标对象本身的引用,构成死循环,结束此次遍历
if (target === copy) {
continue;
}

//如果需要进行深度拷贝,且copy类型为对象或数组
if (deep && copy && (jQuery.isPlainObject(copy) || jQuery.isArray(copy))) {

//如果src类型为对象或数组,则clone记录src
//否则colne记录与copy类型一致的空值(空数组或空对象)
var clone = src && (jQuery.isPlainObject(src) || jQuery.isArray(src)) ? src : jQuery.isArray(copy) ? [] : {};

//对copy迭代深度复制
target[name] = jQuery.extend(deep, clone, copy);

//如果不需要进行深度拷贝
} else if (copy !== undefined) {

//直接将copy复制给目标对象
target[name] = copy;
}
}
}
}

//返回处理后的目标对象
return target;
};


/**
* jQuery框架本身对extend函数的使用非常频繁
* 典型示例为jQuery.ajax
*
*/

//使用extend对jQuery对象本身进行扩展,只给了一个参数对象
//该对象中的属性将被追加到jQuery对象中
jQuery.extend({

//jQuery.ajax
//$.ajax

//这里的origSettings参数是自定义的ajax配置
//jQuery对象本身有一个ajaxSettings属性,是默认的ajax配置
ajax: function(origSettings){

//这里使用extend对ajax配置项进行合并
//第一个参数表示进行深度拷贝
//首先将第3个参数jQuery.ajaxSettings(即jQuery默认ajax配置)复制到第2个参数(一个空对象)
//然后将第4个参数(自定义配置)复制到配置对象(覆盖默认配置)
//这里的s就得到了最终的ajax配置项
var s = jQuery.extend(true, {}, jQuery.ajaxSettings, origSettings);

//其它相关代码...(省略)
}
});
《餐馆点餐管理系统——基于Java和MySQL的课程设计解析》 在信息技术日益发达的今天,餐饮行业的数字化管理已经成为一种趋势。本次课程设计的主题是“餐馆点餐管理系统”,它结合了编程语言Java和数据库管理系统MySQL,旨在帮助初学者理解如何构建一个实际的、具有基本功能的餐饮管理软件。下面,我们将深入探讨这个系统的实现细节及其所涉及的关键知识点。 我们要关注的是数据库设计。在“res_db.sql”文件中,我们可以看到数据库的结构,可能包括菜品表、订单表、顾客信息表等。在MySQL中,我们需要创建这些表格并定义相应的字段,如菜品ID、名称、价格、库存等。此外,还要设置主键、外键来保证数据的一致性和完整性。例如,菜品ID作为主键,确保每个菜品的唯一性;订单表中的顾客ID和菜品ID则作为外键,与顾客信息表和菜品表关联,形成数据间的联系。 接下来,我们来看Java部分。在这个系统中,Java主要负责前端界面的展示和后端逻辑的处理。使用Java Swing或JavaFX库可以创建用户友好的图形用户界面(GUI),让顾客能够方便地浏览菜单、下单。同时,Java还负责与MySQL数据库进行交互,通过JDBC(Java Database Connectivity)API实现数据的增删查改操作。在程序中,我们需要编写SQL语句,比如INSERT用于添加新的菜品信息,SELECT用于查询所有菜品,UPDATE用于更新菜品的价格,DELETE用于删除不再提供的菜品。 在系统设计中,我们还需要考虑一些关键功能的实现。例如,“新增菜品和价格”的功能,需要用户输入菜品信息,然后通过Java程序将这些信息存储到数据库中。在显示所有菜品的功能上,程序需要从数据库获取所有菜品数据,然后在界面上动态生成列表或者表格展示。同时,为了提高用户体验,可能还需要实现搜索和排序功能,允许用户根据菜品名称或价格进行筛选。 另外,安全性也是系统设计的重要一环。在连接数据库时,要避免SQL注入攻击,可以通过预编译的PreparedStatement对象来执行SQL命令。对于用户输入的数据,需要进行验证和过滤,防止非法字符和异常值。 这个“餐馆点餐管理系统”项目涵盖了Java编程、数据库设计与管理、用户界面设计等多个方面,是一个很好的学习实践平台。通过这个项目,初学者不仅可以提升编程技能,还能对数据库管理和软件工程有更深入的理解。在实际开发过程中,还会遇到调试、测试、优化等挑战,这些都是成长为专业开发者不可或缺的经验积累
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值