Rumah > Artikel > hujung hadapan web > Bagaimana React JSX Berubah Menjadi JavaScript Di Sebalik Tabir
Apabila anda menulis React, anda akan sering melihat JSX – sintaks yang kelihatan seperti HTML dalam kod JavaScript anda. Tetapi pernahkah anda terfikir bagaimana kod ini berjalan dalam penyemak imbas?
Inilah keajaibannya: JSX bukan JavaScript yang sah! Pelayar tidak dapat memahaminya secara langsung. Di sebalik tabir, alat seperti Babel melangkah masuk untuk menukar (atau "transpile") JSX kepada JavaScript biasa.
1.Anda menulis JSX – Ia kelihatan seperti HTML tetapi hidup dalam komponen React anda. Contohnya:
const element = <h1>Hello, World!</h1>;
2.Babel mengubahnya – Semasa proses binaan, Babel menukar JSX kepada JavaScript tulen menggunakan React.createElement:
const element = React.createElement('h1', null, 'Hello, World!');
3.JavaScript dalam penyemak imbas – Akhirnya, JavaScript standard ini ialah apa yang penyemak imbas laksanakan, membina DOM secara dinamik.
Babel ialah penyusun JavaScript yang berkuasa yang membolehkan anda menggunakan ciri JavaScript terkini (termasuk JSX dalam React) sambil memastikan keserasian merentas pelayar dan persekitaran yang berbeza. Berikut ialah pecahan cara Babel berfungsi:
1.Menghuraikan
Babel bermula dengan menghuraikan kod JavaScript atau JSX moden anda ke dalam Pokok Sintaks Abstrak (AST). AST ialah struktur seperti pepohon terperinci yang mewakili kod dengan cara yang mudah untuk Babel (dan alatan lain) untuk menganalisis dan memanipulasi. Semasa langkah ini, Babel membaca kod tetapi tidak mengubahnya lagi.
Sebagai contoh, Babel mengambil kod JSX ini:
const element = <h1>Hello, World!</h1>;
Dan menjana AST, yang mewakili struktur kod ini.
2.Mengubah
Seterusnya, Babel menggunakan siri pemalam pada AST. Setiap pemalam bertanggungjawab untuk mengubah bahagian tertentu AST mengikut peraturan yang ditakrifkannya. Transformasi ini boleh termasuk menukar sintaks JavaScript moden (seperti fungsi anak panah atau async/menunggu) kepada versi yang lebih lama, serasi penyemak imbas.
Untuk JSX, Babel mengubah:
const element = <h1>Hello, World!</h1>;
const element = React.createElement('h1', null, 'Hello, World!');
3. Penjanaan Kod
Setelah semua transformasi selesai, Babel menjana kod JavaScript daripada AST yang diubah. Ini ialah langkah terakhir di mana output boleh dibaca manusia dihasilkan, yang boleh dilaksanakan oleh penyemak imbas atau Node.js.
Mari Buat kesimpulan...
JSX membolehkan anda menulis kod UI berasaskan komponen yang lebih intuitif, tetapi Babel dan masa jalan JavaScript yang menghidupkannya. Memahami penukaran ini membantu anda menyelesaikan masalah dengan lebih baik dan menulis apl React yang lebih dioptimumkan.
Atas ialah kandungan terperinci Bagaimana React JSX Berubah Menjadi JavaScript Di Sebalik Tabir. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!