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

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 menjangkakanmodule2的部分是可以在任何其他(模块)对象上调用的方法,这些对象具有.array属性。为此,你需要通过this.arrayuntuk 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
    Tentang kita Penafian Sitemap
    Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!