Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mengekalkan Konteks dalam Panggilan Balik `setTimeout` JavaScript?

Bagaimana untuk Mengekalkan Konteks dalam Panggilan Balik `setTimeout` JavaScript?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-15 12:44:26290semak imbas

How to Preserve Context in JavaScript's `setTimeout` Callbacks?

Memelihara Konteks apabila Menggunakan Panggilan Balik setTimeout

Apabila menggunakan setTimeout dalam JavaScript, menghantar konteks yang sesuai kepada fungsi panggil baliknya boleh menjadi penting. Sebagai contoh, katakan anda ingin memanggil kaedah this.tip.destroy() selepas 1000 milisaat, dengan syarat this.options.destroyOnHide adalah benar. Menggunakan kaedah ini, bagaimanapun, menghasilkan ini merujuk kepada objek tetingkap global.

Penyelesaian untuk Memelihara Konteks

Sepanjang evolusi JavaScript, pelbagai pendekatan telah muncul untuk menyelesaikan konteks ini isu:

  • Konteks Mengikat (ES5): Kaedah bind(), yang diperkenalkan dalam ES5, membolehkan anda mencipta fungsi baharu dengan nilai ini yang dipratakrifkan, menghalang perkara global ini daripada merayap masuk:

    if (this.options.destroyOnHide) {
    setTimeout(function() { this.tip.destroy() }.bind(this), 1000);
    }
  • Fungsi Anak Panah (ES6): Fungsi anak panah memudahkan proses ini dengan menghapuskan konsep mereka sendiri nilai ini. Apabila mengakses ini dalam fungsi anak panah, ia mewarisi nilai skop sekelilingnya:

    if (this.options.destroyOnHide) {
    setTimeout(() => { this.tip.destroy() }, 1000);
    }
  • Melalui Konteks sebagai Argumen (HTML5): HTML5 diperkenalkan pendekatan piawai yang melibatkan penghantaran konteks sebagai hujah kepada panggilan balik fungsi:

    if (this.options.destroyOnHide) {
    setTimeout(function(that) { that.tip.destroy() }, 1000, this);
    }

Dengan menggunakan salah satu daripada teknik ini, anda boleh mengekalkan konteks yang diingini dengan berkesan apabila menggunakan panggilan balik setTimeout, memastikan kod anda berfungsi seperti yang dijangkakan.

Atas ialah kandungan terperinci Bagaimana untuk Mengekalkan Konteks dalam Panggilan Balik `setTimeout` JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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