Memahami "new.target"
Spesifikasi ECMAScript 2015 memperkenalkan sifat meta yang dikenali sebagai "new.target," yang digunakan dalam fungsi bukan anak panah untuk menentukan sama ada fungsi itu dipanggil sebagai pembina.
Definisi dan Tujuan
"new.target" merujuk kepada sifat meta pertama dan secara rasmi ditakrifkan dalam §12.3.8 spesifikasi. Tujuan tunggalnya ialah untuk mendapatkan semula nilai semasa nilai dalaman "[[NewTarget]]" fungsi. Nilai ini ditetapkan apabila fungsi dipanggil, serupa dengan pengikatan "ini".
Menurut §8.1.1.3 Rekod Persekitaran Fungsi, nilai "[[NewTarget]]" ditetapkan kepada "[[ Bina]]" newTarget parameter jika fungsi dipanggil sebagai pembina. Jika tidak, nilainya kekal tidak ditentukan.
Kepentingan untuk Kelas ES6
"new.target" memainkan peranan penting dalam pelaksanaan kelas ES6, membolehkan mereka mewarisi daripada objek terbina dalam. Apabila memanggil pembina kelas menggunakan "baru," nilai "ini" belum dimulakan. Walau bagaimanapun, apabila kaedah super() dipanggil, objek dicipta dan ditetapkan untuk mewarisi daripada ".prototaip" pembina "newTarget".
Contoh
Contoh berikut menunjukkan cara "new.target" digunakan dalam warisan kelas:
class Parent { constructor() { // Implicit from super() call: new.target = Child // Implicit because Parent doesn't extend anything: // this = Object.create(new.target.prototype) console.log(new.target) // Child! } } class Child extends Parent { constructor() { // this is uninitialized (and would throw if accessed) // Implicit from new call: new.target = Child super() // this = Reflect.construct(Parent, [], new.target) console.log(this) } } new Child
Dalam contoh ini:
Atas ialah kandungan terperinci Bagaimanakah sifat meta \'new.target\' memudahkan pewarisan kelas ES6?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!