Rumah  >  Artikel  >  hujung hadapan web  >  Fungsi anak panah dan ini

Fungsi anak panah dan ini

PHPz
PHPzasal
2024-07-31 01:28:24807semak imbas

Arrow function and this

Apakah keputusan foo.baz() ini??

const foo = {
  bar: 10,
  baz: () => console.log(this.bar),
};


foo.baz();

Fungsi ini kelihatan seperti ia sepatutnya berfungsi tetapi jika anda menjalankan ini, hasilnya akan menjadi "tidak ditentukan". Kenapa begitu?
Dalam JavaScript, apabila anda menggunakan fungsi anak panah, fungsi console.log(this.bar) akan mencari pembolehubah global, kerana kata kunci "ini" tidak terikat pada objek sekeliling tetapi objek global (tetingkap) dalam penyemak imbas atau persekitaran node.js.
Untuk menyelesaikan masalah ini, kami sama ada menggunakan foo.bar atau menukar sedikit kod dan menggunakan ungkapan fungsi biasa seperti itu

 baz: function () {
    console.log(this.bar);
  },

Atau jika kita perlu menggunakan fungsi anak panah, bukannya memanggil pembolehubah tempatan sebagai this.bar, kita boleh menggunakan nama objek dan memanggil foo.bar seperti itu .

 baz: () => console.log(foo.bar),

Kini output akan menjadi betul 10.

Atas ialah kandungan terperinci Fungsi anak panah dan ini. 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