Mengintegrasikan modul JavaScript
P粉745412116
P粉745412116 2023-09-09 21:45:59
0
1
533

Dalam kod saya, tatasusunan diisytiharkan daripada modul yang diimport. Fungsi yang berkaitan dengan modul ini diimport daripada modul kedua. Berikut ialah versi ringkas kod saya:

Modul pertama yang mengandungi tatasusunan

let module1 = {};
module1.array = [10, 20, 30];

Modul kedua yang mengandungi fungsi

var module2 = {};
module2.fct1 = () => { return array[0]; };
module2.fct2 = () => { return array[1]; };
module2.fct3 = () => { return array[2]; };

Saya ingin menggabungkan dua modul ini menjadi satu entiti:

module1.fct1 = module2.fct1;
module1.fct2 = module2.fct2;
module1.fct3 = module2.fct3;

module1Kini termasuk tatasusunan dan fungsi

{
  array: [10, 20, 30],
  fct1: () => { return array[0];    },
  fct2: () => { return array[1];    },
  fct3: () => { return array[2];    }
}

Walau bagaimanapun, apabila saya memanggil fungsi, tatasusunan nampaknya berada di luar skop fungsi:

console.log (module1.fct1())

Saya mendapat ralat berikut:

Ralat rujukan tidak ditangkap: tatasusunan tidak ditentukan

Jika saya mencipta satu modul yang mengandungi tatasusunan dan fungsi dalam fail yang sama, ia berfungsi.

Soalan saya ialah: Adakah terdapat cara dalam JavaScript untuk menggabungkan dua modul. Matlamat utama saya adalah untuk menghantar modul yang digabungkan ke fungsi lain.

Ini ialah pautan JSFiddle: https://jsfiddle.net/Imabot/rxsfvgda/4/

P粉745412116
P粉745412116

membalas semua(1)
P粉254077747

Nampaknya anda menjangkakan module2的部分是可以在任何其他(模块)对象上调用的方法,这些对象具有.array属性。为此,你需要通过this.array untuk mengakses tatasusunan, dan perlu menggunakan sintaks kaedah dan bukannya fungsi anak panah:

var module2 = {};
module2.fct1 = function() { return this.array[0]; };
module2.fct2 = function() { return this.array[1]; };
module2.fct3 = function() { return this.array[2]; };

atau lebih ringkas:

var module2 = {
  fct1() { return this.array[0]; },
  fct2() { return this.array[1]; },
  fct3() { return this.array[2]; },
};
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan