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
Lepaskan: 2024-12-15 12:44:26
asal
352 orang telah melayarinya

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);
    }
    Salin selepas log masuk
  • 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);
    }
    Salin selepas log masuk
  • 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);
    }
    Salin selepas log masuk

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!

sumber:php.cn
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