【JavaScript】$.extend使用心得及源码研究

最近写多了js的面向对象编程,用$.extend写继承写得很顺手。但是在使用过程中发现有几个问题。

1.深拷贝

$.extend默认是浅拷贝,这意味着在继承复杂对象时,对象中内嵌的对象无法被拷贝到。

因此如果要深拷贝,则需要将第一个参数设置为true。

如:

var a = { a:1 };
var b = { b:{c:1} };
$.extend(a,b);
a = { a:1,b:{c:1} };

2.对象覆盖

在进行面向对象编程时,有这么一种情况。

比如有一个公共对象,某个类在实例化的时候,都要继承这个公共对象。那么在实例化这个类的时候,要保证这个公共对象不被改变,以确保所有实例对象都能继承同一个公共对象。

复制代码
var common =  { a:1,b:1 };

var A = function(option){
     this.option = $.extend(common,option);  
}

var a = new A({ a:2 });
var b = new A({ b:2 });

a.option = { a:2,b:1 }
b.option = { a:2,b:2 }
复制代码

从上面这个例子我们可以看到。但在实例化a的时候,common已经被改变了。因此实例化b的时候,a.option.a不是我们想要的1,而是在实例化a时就被污染的2.

针对这个问题。需要这么修改:

1
2
3
4
5
6
7
8
9
10
11
var common =  { a:1,b:1 };
 
var A = function(option){
     this.option = $.extend({},common,option); 
}
 
var a = new A({ a:2 });
var b = new A({ b:2 });
 
a.option = { a:2,b:1 }
b.option = { a:2,b:2 }

在用extend引用common的时候,第一个参数使用一个空的对象,这样就能保证common不会被污染。

3.$.extend源码研究

由于时间关系,后续再写。

 

posted @   のんきネコ  阅读(347)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2016-04-11 【C#】 知乎用户网络爬虫
点击右上角即可分享
微信分享提示