Rumah > hujung hadapan web > tutorial js > Penjelasan terperinci tentang objek klon dalam javascript

Penjelasan terperinci tentang objek klon dalam javascript

PHPz
Lepaskan: 2018-09-30 11:00:42
asal
2383 orang telah melayarinya

Artikel ini terutamanya memperkenalkan kaedah pengklonan objek dalam JavaScript Rakan yang memerlukan boleh merujuknya.

Semasa pembangunan, adalah perkara biasa untuk mengganggu hubungan rujukan antara objek dan hanya mahu membuat salinan objek tidak dapat dielakkan.

Dalam JavaScript, kaedah mudah ialah menggunakan fungsi JSON untuk merangkai objek menjadi rentetan, dan kemudian menghuraikannya menjadi objek baharu. Atau hanya mencari kod dari Internet Masih terdapat banyak kod klon dalam komuniti sumber terbuka.

Walaupun kod itu boleh ditemui, perkara akan sentiasa menjadi milik orang lain dan pembelajaran kod dengan tangan akan sentiasa menjadi tema yang berterusan.

Saya sendiri menulis dua fungsi klon:

cloneOwn: Mengklon sifat objek tersuai sendiri, tidak termasuk sifat yang diwarisi Sifat ini boleh menjadi jenis data asas dan tatasusunan, Objek tersuai, anda boleh tentukan senarai nama atribut untuk diklon.

cloneArray: Mengklon tatasusunan Elemen dalam tatasusunan boleh menjadi objek atau jenis asas.

//第一个参数是被克隆的对象,第二个参数是需要克隆的属性列表
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;
}
Salin selepas log masuk
//克隆数组
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;
}
Salin selepas log masuk

Panggil

1 kerap mengklon objek tersuai:

var a = {
  name:'frank',
  age:20
};
var b= cloneOwn(a);
Salin selepas log masuk

2. Tentukan atribut klon

var a = {
    name:'frank',
    age:20,
    address:'any where'
};
var b = cloneOwne(a, ['name', 'age']);
Salin selepas log masuk

3. Klonkan objek tersuai yang mengandungi atribut tatasusunan

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);
Salin selepas log masuk

4. sebagai , terdapat beberapa masalah dengan pengklonan objek terbina dalam, seperti jenis datatime.

var a = [
   {
      name:'frank',
      age:20
    },
    {
       name:'leon',
       age:30
     }
];
var b = cloneArray(a);
Salin selepas log masuk
Masalah menangani masalah, dan proses pembelajaran seperti itu juga perlu.

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan