您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

javascript中clone克隆对象/函数代码详解

2024/4/23 20:31:47发布24次查看
javascript中,简单的方法就是用json函数,将对象stringify成字符串,再parse成一个新对象。要么就是从网上搜个代码,开源社区里面clone的代码还是有不少的。
  代码虽然可以找得到,但,东西永远是别人的,动手学着码永远是个不变的主题。
  写了两个克隆的函数:
  cloneown:克隆自定义对象的自有属性,不包括继承的属性,属性可以是基本数据类型和数组,自定义的对象,可以制定要克隆的属性名称列表。
  clonearray: 克隆数组,数组内的元素可以是对象,基本类型。
//第一个参数是被克隆的对象,第二个参数是需要克隆的属性列表 function cloneown() { var obj = arguments[0]; if (typeof obj === 'undefined' || obj === null) return {}; if (typeof obj !== 'object') return obj; //第二个参数是属性名称列表,就采用该列表进行刷选 //否则就克隆所有属性 var attrs = arguments[1]; var enable_spec_attr = true; if (!(attrs instanceof array)) { //console.log(attrs); attrs = obj; enable_spec_attr = false; } var result = {}; var i; for (i in attrs) { attr = enable_spec_attr? attrs[i]: i; //console.log(attr); if (obj.hasownproperty(attr)) { if (obj[attr] instanceof array) { result[attr] = clonearray(obj[attr]); } else if (typeof obj[attr] === 'object') { result[attr] = cloneown(obj[attr]); } else { result[attr] = obj[attr]; } } } return result; }
//克隆数组 function clonearray(array) { if (typeof array === 'undefined' || array === null) return []; if (!(array instanceof array)) return []; result = []; var i; for(i in array) { if (typeof array[i] !== 'object') { result[i] = array[i]; continue; } //clone object result[i] = cloneown(array[i]); } return result; }
调用
1.常规克隆自定义对象:
var a = { name:'frank', age:20 }; var b= cloneown(a);
2.指定克隆的属性
var a = { name:'frank', age:20, address:'any where' }; var b = cloneowne(a, ['name', 'age']);
3.克隆内含有数组属性的自定义对象
var a = { name: 'kxh', age: 20, books: ['hai','ho','ali'], likes: [ {wname: 'kaili', wage: 81, fav: "aaaaa"}, {wname: 'seli', wage: 82, fav: "bbb"}, {wname: 'ailun', wage: 83, fav: "ccc"},] }; var b = cloneowne(a);
4.克隆数组,内含有自定义对象
var a = [ { name:'frank', age:20 }, { name:'leon', age:30 } ]; var b = clonearray(a);
以上就是javascript中clone克隆对象/函数代码详解的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product