Rumah > hujung hadapan web > tutorial js > Penutupan JavaScript Secara Mendalam: Membuka Kunci Kuasa Skop Leksikal

Penutupan JavaScript Secara Mendalam: Membuka Kunci Kuasa Skop Leksikal

Mary-Kate Olsen
Lepaskan: 2024-12-22 17:34:11
asal
470 orang telah melayarinya

JavaScript Closures in Depth: Unlocking the Power of Lexical Scope

Penutupan JavaScript Secara Mendalam: Panduan Komprehensif

Penutupan ialah salah satu konsep yang paling asas dan berkuasa dalam JavaScript. Mereka membenarkan fungsi mengekalkan akses kepada skopnya, walaupun selepas fungsi luar telah dilaksanakan. Ini menjadikan penutupan sebagai alat penting untuk mencipta pembolehubah persendirian, mengurus keadaan dan mereka bentuk corak yang canggih seperti kari dan aplikasi separa.


1. Apakah Penutupan?

Penutupan dicipta apabila fungsi "mengingat" skop leksikalnya, walaupun apabila fungsi itu dilaksanakan di luar skop tersebut.

Takrif:

Penutupan ialah fungsi yang mempunyai akses kepada pembolehubah fungsi lampirannya, walaupun selepas fungsi luar telah kembali.


2. Sintaks Penutupan

Penutupan dibuat apabila fungsi bersarang dikembalikan atau digunakan dalam cara yang berterusan di luar pelaksanaan fungsi induknya.

function outerFunction() {
  const outerVariable = "I'm an outer variable";

  function innerFunction() {
    console.log(outerVariable); // Access outerVariable
  }

  return innerFunction;
}

const closureFunction = outerFunction();
closureFunction(); // Output: "I'm an outer variable"
Salin selepas log masuk
Salin selepas log masuk

3. Cara Penutupan Berfungsi

Penutupan memanfaatkan skop leksikal JavaScript:

  • Skop Leksikal: Skop di mana fungsi diisytiharkan menentukan pembolehubah yang boleh diakses olehnya.

Apabila outerFunction kembali, konteks pelaksanaannya dimusnahkan, tetapi innerFunction yang dikembalikan mengekalkan akses kepada outerVariable kerana penutupan.


4. Contoh Penutupan

a) Mencipta Pembolehubah Peribadi

function counter() {
  let count = 0; // Private variable

  return {
    increment: function () {
      count++;
      console.log(count);
    },
    decrement: function () {
      count--;
      console.log(count);
    },
  };
}

const myCounter = counter();
myCounter.increment(); // 1
myCounter.increment(); // 2
myCounter.decrement(); // 1
Salin selepas log masuk

Kiraan pembolehubah hanya boleh diakses melalui kaedah yang dikembalikan, memastikan privasi.


b) Kilang Berfungsi

Penutupan membolehkan kami mencipta fungsi dengan gelagat prakonfigurasi.

function multiplier(factor) {
  return function (number) {
    return number * factor;
  };
}

const double = multiplier(2);
const triple = multiplier(3);

console.log(double(5)); // 10
console.log(triple(5)); // 15
Salin selepas log masuk

c) Mengekalkan Keadaan dalam Kod Asynchronous

Penutupan biasanya digunakan untuk mengekalkan keadaan dalam operasi tak segerak.

function greetAfterDelay(name) {
  setTimeout(() => {
    console.log(`Hello, ${name}!`);
  }, 2000);
}

greetAfterDelay("Alice");
// Output after 2 seconds: "Hello, Alice!"
Salin selepas log masuk

Di sini, penutupan memastikan pembolehubah nama dikekalkan untuk panggilan balik setTimeout.


5. Kes Penggunaan Biasa untuk Penutupan

  1. Menyembunyikan Data dan Enkapsulasi

    Penutupan mewujudkan pembolehubah dan kaedah peribadi, konsep utama dalam pengaturcaraan berorientasikan objek.

  2. Panggil balik

    Digunakan secara meluas dalam JavaScript tak segerak untuk mengurus pendengar acara, janji dan pemasa.

  3. Pengaturcaraan Fungsional

    Teras kepada fungsi tertib lebih tinggi seperti peta, penapis dan pengurangan.

  4. Kari dan Pemakaian Separa

    Membolehkan memecahkan fungsi kepada unit yang lebih kecil dan boleh digunakan semula.


6. Penutupan dan Ingatan

Penutupan mengekalkan rujukan kepada pembolehubah dalam skopnya, yang boleh membawa kepada kebocoran memori jika tidak diurus dengan betul.

Mengelakkan Isu Ingatan:

  • Alih keluar pendengar acara apabila tidak diperlukan lagi.
  • Berhati-hati dengan penutupan tahan lama dalam aplikasi besar.

7. Salah Tanggapan Mengenai Penutupan

Mitos 1: Penutupan Adalah Rumit

Penutupan adalah mudah setelah anda memahami skop leksikal.

Mitos 2: Penutupan Memperlahankan Prestasi

Walaupun penutupan mengekalkan ingatan, kesan prestasinya boleh diabaikan dalam kebanyakan kes penggunaan.


8. Kelebihan Penutupan

  • Encapsulation: Melindungi pembolehubah daripada akses yang tidak diingini.
  • Modulariti: Menggalakkan fungsi yang boleh diguna semula dan bebas.
  • Pengurusan Negeri: Memudahkan pengurusan keadaan dalam pengaturcaraan berfungsi.

9. Contoh Dunia Sebenar

a) Melantun dengan Penutupan

Fungsi yang mengehadkan kekerapan fungsi lain dipanggil.

function outerFunction() {
  const outerVariable = "I'm an outer variable";

  function innerFunction() {
    console.log(outerVariable); // Access outerVariable
  }

  return innerFunction;
}

const closureFunction = outerFunction();
closureFunction(); // Output: "I'm an outer variable"
Salin selepas log masuk
Salin selepas log masuk

10. Kesimpulan

Penutupan ialah ciri serba boleh JavaScript, mendayakan corak berkuasa seperti pembolehubah peribadi, panggilan balik dan fungsi stateful. Dengan memahami cara penutupan berfungsi, anda boleh menulis kod yang lebih mantap, modular dan boleh diselenggara.

Menguasai penutupan membuka kunci potensi penuh JavaScript sebagai bahasa pengaturcaraan yang berfungsi dan dipacu peristiwa.

Hai, saya Abhay Singh Kathayat!
Saya seorang pembangun timbunan penuh dengan kepakaran dalam kedua-dua teknologi hadapan dan belakang. Saya bekerja dengan pelbagai bahasa pengaturcaraan dan rangka kerja untuk membina aplikasi yang cekap, berskala dan mesra pengguna.
Jangan ragu untuk menghubungi saya melalui e-mel perniagaan saya: kaashshorts28@gmail.com.

Atas ialah kandungan terperinci Penutupan JavaScript Secara Mendalam: Membuka Kunci Kuasa Skop Leksikal. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan