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.
Penutupan dicipta apabila fungsi "mengingat" skop leksikalnya, walaupun apabila fungsi itu dilaksanakan di luar skop tersebut.
Penutupan ialah fungsi yang mempunyai akses kepada pembolehubah fungsi lampirannya, walaupun selepas fungsi luar telah kembali.
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"
Penutupan memanfaatkan skop leksikal JavaScript:
Apabila outerFunction kembali, konteks pelaksanaannya dimusnahkan, tetapi innerFunction yang dikembalikan mengekalkan akses kepada outerVariable kerana penutupan.
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
Kiraan pembolehubah hanya boleh diakses melalui kaedah yang dikembalikan, memastikan privasi.
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
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!"
Di sini, penutupan memastikan pembolehubah nama dikekalkan untuk panggilan balik setTimeout.
Menyembunyikan Data dan Enkapsulasi
Penutupan mewujudkan pembolehubah dan kaedah peribadi, konsep utama dalam pengaturcaraan berorientasikan objek.
Panggil balik
Digunakan secara meluas dalam JavaScript tak segerak untuk mengurus pendengar acara, janji dan pemasa.
Pengaturcaraan Fungsional
Teras kepada fungsi tertib lebih tinggi seperti peta, penapis dan pengurangan.
Kari dan Pemakaian Separa
Membolehkan memecahkan fungsi kepada unit yang lebih kecil dan boleh digunakan semula.
Penutupan mengekalkan rujukan kepada pembolehubah dalam skopnya, yang boleh membawa kepada kebocoran memori jika tidak diurus dengan betul.
Penutupan adalah mudah setelah anda memahami skop leksikal.
Walaupun penutupan mengekalkan ingatan, kesan prestasinya boleh diabaikan dalam kebanyakan kes penggunaan.
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"
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!