jQuery.extend与jQuery.fn.extend

本文详细介绍了 jQuery 中的 $.extend() 方法及其设计原理。该方法用于合并多个对象,并将它们的属性复制到目标对象中。文章解释了如何使用此方法进行浅拷贝或深拷贝,以及如何扩展 jQuery 的原型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

$.extend()常用的几种方法 参考http://www.cnblogs.com/zikai/p/5074686.html  (先看这个更容易理解 $.extend()设计原理)

接下来详细介绍它的实现

jQuery.extend = jQuery.fn.extend = function() {
	var options, name, src, copy, copyIsArray, clone,
		target = arguments[ 0 ] || {},
		i = 1,
		length = arguments.length,   
		deep = false;         //默认是无需深度遍历

	if ( typeof target === "boolean" ) { //判断第一参数是否为boolean,表示是否要深度遍历
		deep = target;

		target = arguments[ i ] || {};
		i++;
	}

	if ( typeof target !== "object" && !jQuery.isFunction( target ) ) {  //遍历的对象必须为object或者function
		target = {};
	}

	if ( i === length ) {           //判断是否是自身扩展,自身扩展就是所有遍历的方法属性都添加到$.fn,不是自身扩展的时候所有
		target = this;                     //的对象都扩展到第一个非boolean的参数中(结合上面的链接理解起来更轻松)
		i--;
	}

	for ( ; i < length; i++ ) {  //遍历传入的所有参数,进行相应的对象扩展

	
		if ( ( options = arguments[ i ] ) != null ) {
                         //遍历一个参数的所有属性、方法,非深度扩展时直接覆盖前面对象,深度扩展时递归进入对象里面以
                         //基本类型数据覆盖前面数据
			for ( name in options ) 
			{  
				src = target[ name ];
				copy = options[ name ];
				if ( target === copy ) {  //防止无限循环
					continue;
				}
				if ( deep && copy && ( jQuery.isPlainObject( copy ) ||
					( copyIsArray = Array.isArray( copy ) ) ) ) {

					if ( copyIsArray ) {
						copyIsArray = false;
						clone = src && Array.isArray( src ) ? src : [];

					} else {
						clone = src && jQuery.isPlainObject( src ) ? src : {};
					}

			
					target[ name ] = jQuery.extend( deep, clone, copy ); //递归的方式深度遍历对象、数组
				} else if ( copy !== undefined ) { // 无需深度扩展或者已经是基本类型数据,就直接扩展
					target[ name ] = copy;
				}
			}
		}
	}
	return target;
};

			
注意:这个方法表示 jQuery.extend 与jQuery.fn.extend 指向同一个引用,而里面的this 根据调用者改变,指向jQuery.extend 或者jQuery.fn

eg :  $.extend(dest,src1,src2,src3...);  把src1后面的对象全部扩展到dest里面,修改了dest原对象,最后返回的是扩展之后的dest

eg:$.extend({},src1,src2,src3...)   添加一个空对象,所有参数扩展到{} 里面,保留了原对象

eg:  $.fn.extend({src1,src2..})  把src1...扩展到$.fn里面,而$.fn.init.prototype = $.fn,这样就扩展了$实例化方法

PS: 

     1、当我们需要扩展$()实例化方法的时候就需要用到   $.fn.extend, 所有的jquery插件都是通过这个入口扩展它的实例方法

     2、$.extend({})表示扩展的方法添加到$中,通过 ' $. ' 引用, $.fn.extend({}),扩展到$.fn里面,通过 '$("节点").'  引用


内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新一代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值