您的位置:首页 > Web前端 > JavaScript

JavaScript的clone函数的实现及应用条件

2008-12-04 11:15 267 查看
1 function clone(obj){
2     if(obj == null || typeof(obj) != 'object')
3         return obj;
4     if(obj.constructor == Date)
5         return new obj.constructor(obj.valueOf());
6     var temp = new obj.constructor(); // changed (twice)
7     for(var key in obj)
8         temp[key] = clone(obj[key]);
9     return temp;
10 }


那一般在什么时候会用到这个clone函数呢?比如说,有些情况下需要从一个页面向另外一个页面传值,比如A页面创建了一个对象,传给B页面,用户关闭了A页面,obj会随之清除,那么B页面引用的就是一个空值,所以在B页面接收到一个对象的时候,拷贝一份留给自己,就能避免这样的错误。

根据上面实例,我们可以大体推导出在什么情况下我们需要用到这个clone函数:

同时存在一个对象的多个引用,我们把每个引用所在的上下文称为场景,当我们不希望一个场景下对这个对象的修改反映到其它场景下时,这时我们就可以用clone函数。

参考:

JavaScript Clone function,http://keithdevens.com/weblog/archive/2007/Jun/07/javascript.clone

/article/4589024.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐