小兔网

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克隆对象/函数代码详解的知识。速戳>>知识兔学习精品课!