Fungsi anak panah dan ini

PHPz
Lepaskan: 2024-07-31 01:28:24
asal
837 orang telah melayarinya

Arrow function and this

Apakah keputusan foo.baz() ini??

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


foo.baz();

Salin selepas log masuk

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);
  },

Salin selepas log masuk

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),

Salin selepas log masuk

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!

sumber:dev.to
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan