Rumah >hujung hadapan web >tutorial js >Kes aplikasi penutupan biasa dalam pengaturcaraan
Senario penutupan aplikasi biasa dalam pengaturcaraan memerlukan contoh kod khusus
Dalam pengaturcaraan, penutupan (Penutupan) ialah konsep yang kuat dan biasa. Ini bermakna fungsi boleh mengakses dan memanipulasi pembolehubah dalam skop leksikal pada masa definisinya. Penutupan boleh memainkan peranan dalam banyak senario Berikut akan memperkenalkan beberapa senario aplikasi biasa dan memberikan contoh kod khusus.
function createCounter() { let count = 0; return function() { count++; console.log(count); } } const counter = createCounter(); counter(); // 输出 1 counter(); // 输出 2
Dalam contoh ini, fungsi createCounter
mengembalikan fungsi dalaman yang boleh mengakses dan mengubah suai pembolehubah count
. Pembolehubah count
tidak boleh diakses terus dari luar Anda hanya boleh menambah dan mengeluarkan nilai count
dengan memanggil fungsi counter
. createCounter
函数返回一个内部函数,该内部函数可以访问并修改 count
变量。外部无法直接访问 count
变量,只能通过调用 counter
函数来递增并输出 count
的值。
function debounce(callback, delay) { let timerId = null; return function() { if (timerId) { clearTimeout(timerId); } timerId = setTimeout(callback, delay); } } function inputChange() { console.log('Input changed.'); } const inputElement = document.getElementById('input'); inputElement.addEventListener('input', debounce(inputChange, 500));
在这个例子中,debounce
函数返回一个闭包,内部定义了一个 timerId
变量。当 input
事件触发时,闭包内部的函数会先清除之前的定时器,然后再设置一个新的定时器,确保在 delay
毫秒后执行回调函数。
function fetchData(url) { return new Promise(function(resolve, reject) { fetch(url).then(function(response) { resolve(response); }).catch(function(error) { reject(error); }); }); } function handleResponse(response) { console.log(response); } fetchData('https://api.example.com/data').then(handleResponse);
在这个例子中,fetchData
函数返回一个 Promise,并在其内部定义了一个闭包。在闭包内部的回调函数中,可以访问外部函数的上下文环境,包括 resolve
和 reject
Nyahlantun dan pendikit ialah kaedah untuk mengehadkan fungsi panggil balik semasa memproses acara. Sebagai contoh, apabila pengguna secara berterusan mencetuskan peristiwa berulang, anti goncang boleh membenarkan fungsi panggil balik dilaksanakan sekali sahaja selepas pencetus terakhir, dan pendikit boleh membenarkan fungsi panggil balik dilaksanakan sekali dalam selang masa tertentu. Berikut ialah contoh fungsi nyahlantun yang dilaksanakan menggunakan penutupan:
🎜rrreee🎜Dalam contoh ini, fungsidebounce
mengembalikan penutupan dan mentakrifkan pembolehubah timerId
secara dalaman . Apabila peristiwa input
dicetuskan, fungsi di dalam penutupan akan mengosongkan pemasa sebelumnya dahulu, dan kemudian menetapkan pemasa baharu, memastikan fungsi panggil balik dilaksanakan selepas kelewatan
milisaat . 🎜fetchData
mengembalikan Janji dan mentakrifkan penutupan di dalamnya. Dalam fungsi panggil balik dalam penutupan, anda boleh mengakses konteks fungsi luaran, termasuk fungsi resolve
dan reject
. 🎜🎜Penutupan ialah konsep pengaturcaraan yang berkuasa dan biasa, selalunya digunakan untuk melaksanakan pembolehubah persendirian, fungsi pendikit anti goncang dan menyimpan keadaan konteks. Di atas adalah senario aplikasi biasa penutupan dalam pengaturcaraan, dan contoh kod khusus disediakan. Dengan memahami secara mendalam prinsip dan senario aplikasi penutupan, kami boleh menggunakannya dengan lebih baik untuk menyelesaikan masalah praktikal. 🎜Atas ialah kandungan terperinci Kes aplikasi penutupan biasa dalam pengaturcaraan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!