


Konteks Perlaksanaan JavaScript – Cara Kod JS Berjalan Di Belakang Tabir
Sebelum memahami apa itu Konteks Pelaksanaan JavaScript, kita perlu tahu bagaimana dan dalam persekitaran mana kita boleh menjalankan kod JavaScript.
Pertama sekali, kami boleh menjalankan JavaScript dalam dua persekitaran:
- Melalui Penyemak Imbas
- Melalui Node.js
Bagaimanakah kod JavaScript dijalankan pada komputer kami?
Apabila kami menulis kod JavaScript pada komputer kami dan kemudian cuba menjalankannya, kod tersebut mula-mula pergi ke sama ada Penyemak Imbas atau Node.js.
Walau bagaimanapun, kod JavaScript yang kami tulis tidak difahami secara langsung oleh Penyemak Imbas atau Node.js. Pada ketika ini, kedua-duanya menghantar kod ke Enjin JavaScript yang terbina di dalamnya. Terdapat pelbagai jenis enjin, contohnya:
- Enjin V8 dalam Google Chrome,
- SpiderMonkey dalam Mozilla Firefox,
- Enjin V8 dalam Node.js, dsb.
Seterusnya, Enjin JavaScript menyusun kod JavaScript ke dalam kod mesin. Kod mesin ini kemudiannya dihantar ke komputer, yang melaksanakannya, dan kami melihat output dipaparkan.
Sebagai pengaturcara, kita perlu mempunyai pemahaman yang baik tentang langkah perantaraan ini, iaitu, cara Enjin JavaScript menyusun kod JavaScript ke dalam kod mesin.
Jadi, sekarang kita perlu memahami cara Enjin JavaScript berfungsi. Enjin JavaScript berfungsi dalam dua cara untuk menukar kod kepada kod mesin. Yang pertama ialah Tafsiran dan yang kedua ialah Kompilasi. Jadi, apakah itu Tafsiran dan Kompilasi?
Apakah Tafsiran, dan Bagaimana Ia Berfungsi?
Tafsiran ialah proses membaca semua kod sumber yang ditulis dalam bahasa peringkat tinggi baris demi baris dan menukar setiap baris kepada kod mesin serta-merta selepas membacanya. Jika terdapat ralat semasa membaca baris kod, prosesnya berhenti di situ, memudahkan pengaturcara mengenal pasti ralat tersebut. Ini menjadikan penyahpepijatan menjadi mudah. Walau bagaimanapun, memandangkan proses ini membaca kod baris demi baris, ia adalah lebih perlahan.
Apakah Kompilasi, dan Bagaimana Ia Berfungsi?
Kompilasi ialah proses menukar semua kod sumber yang ditulis dalam bahasa peringkat tinggi kepada kod mesin sekaligus. Dalam kes ini, walaupun terdapat ralat dalam kod, ia masih akan menyusun dan hanya menunjukkan ralat semasa runtime. Akibatnya, ia menjadi lebih sukar bagi pengaturcara untuk mengenal pasti ralat, menjadikan penyahpepijatan lebih mencabar. Walau bagaimanapun, memandangkan keseluruhan kod sumber ditukar kepada kod mesin sekaligus, proses ini secara perbandingan lebih pantas. Jadi sekarang, persoalan timbul: Adakah JavaScript adalah bahasa yang disusun atau ditafsirkan?
Adakah JavaScript Bahasa yang Disusun atau Ditafsirkan?
Pada mulanya, JavaScript dianggap sebagai bahasa yang ditafsirkan. Walau bagaimanapun, memandangkan proses ini agak perlahan, enjin JavaScript moden mula menggunakan teknik baharu yang menggabungkan kedua-dua tafsiran dan kompilasi, yang dikenali sebagai Kompilasi Just-In-Time (JIT). Proses ini menggabungkan tafsiran dan penyusunan untuk menukar kod kepada kod mesin. Akibatnya, ia adalah lebih cepat dan lebih mudah untuk nyahpepijat berbanding kaedah lama.
Untuk memahami cara Kompilasi Just-In-Time (JIT) JavaScript berfungsi, kita perlu memahami Konteks Pelaksanaan JavaScript. Sekarang mari cuba memahami Konteks Pelaksanaan JavaScript.
Konteks Perlaksanaan JavaScript
Mula-mula, lihat contoh kod berikut.
Contoh Kod
var a = 1; function one() { console.log(a); function two() { console.log(b); var b = 2; function three(c) { console.log(a + b + c); } three(4); } two(); } one();
Keluaran
1 undefined 7
Apabila kami menjalankan kod, kami cuba mencetak pembolehubah b sebelum ia diisytiharkan dalam fungsi two(), dan output tidak ditentukan. Namun, tiada ralat berlaku. Persoalannya timbul: bagaimana pembolehubah b mempunyai nilai yang tidak ditentukan? Jawapannya terletak pada Konteks Pelaksanaan JavaScript. Kini, kami akan meneroka Konteks Pelaksanaan JavaScript dengan lebih terperinci.
Terdapat dua jenis Konteks Pelaksanaan dalam JavaScript:
- Konteks Pelaksanaan Global
- Konteks Pelaksanaan Fungsi
Setiap Konteks Pelaksanaan melalui dua fasa: Fasa Penciptaan dan Fasa Pelaksanaan.
Konteks Pelaksanaan Global
Apabila kami menjalankan kod JavaScript, perkara pertama yang berlaku ialah Konteks Pelaksanaan Global. Konteks ini mula-mula melalui Fasa Penciptaannya, di mana beberapa perkara berlaku:
Fasa Penciptaan
- Objek Global dicipta.
- Objek ini dicipta dan diberikan nilai Objek Global.
- Objek Pembolehubah dicipta, di mana semua fungsi dan pembolehubah diisytiharkan. Pembolehubah diperuntukkan tidak ditentukan sebagai nilainya dan fungsi diperuntukkan rujukan kepada fungsi masing-masing.
Setelah Fasa Penciptaan selesai, Konteks Pelaksanaan Global beralih ke fasa seterusnya: Fasa Pelaksanaan, di mana lebih banyak langkah berlaku.
Fasa Perlaksanaan
- Pembolehubah yang diisytiharkan dalam Fasa Penciptaan dan dimulakan dengan undefined kini diberikan nilai masing-masing.
- Fungsi yang diisytiharkan dalam Fasa Penciptaan, yang disimpan sebagai rujukan, kini dipanggil dan dilaksanakan.
Konteks Perlaksanaan Fungsi
Apabila fungsi yang dirujuk semasa Fasa Pelaksanaan Konteks Pelaksanaan Global dipanggil, setiap fungsi mencipta Konteks Pelaksanaan Fungsinya sendiri. Sama seperti Konteks Pelaksanaan Global, Konteks Pelaksanaan Fungsi juga melalui Fasa Penciptaan, di mana beberapa langkah berlaku:
Fasa Penciptaan
- Objek parameter dicipta untuk fungsi tersebut.
- Objek ini dicipta dan diberikan nilai Objek Global.
- Objek Pembolehubah dicipta, di mana semua fungsi dan pembolehubah diisytiharkan. Pembolehubah diperuntukkan tidak ditentukan sebagai nilainya dan fungsi diperuntukkan rujukan kepada fungsi masing-masing.
Setelah Fasa Penciptaan selesai, Konteks Pelaksanaan Fungsi beralih ke Fasa Pelaksanaan, di mana lebih banyak langkah berlaku.
Fasa Perlaksanaan
- Pembolehubah yang diisytiharkan dalam Fasa Penciptaan, yang dimulakan dengan undefined, kini diberikan nilai masing-masing.
- Fungsi yang diisytiharkan dalam Fasa Penciptaan kini dipanggil dan dilaksanakan.
Konteks Pelaksanaan Fungsi dalam Fungsi Bersarang
Apabila fungsi dipanggil dalam fungsi lain, Konteks Pelaksanaan Fungsi baharu dicipta untuk setiap fungsi ini. Setiap Konteks Pelaksanaan Fungsi kemudiannya melalui kedua-dua Fasa Penciptaan dan Fasa Pelaksanaan. Proses ini berterusan untuk setiap fungsi yang dipanggil dalam fungsi lain dan setiap fungsi akan melalui fasa ini secara berasingan.
Jom lihat rajah di bawah.
Kami telah melihat bahawa Konteks Pelaksanaan Global dan Konteks Pelaksanaan Fungsi melalui langkah-langkah tertentu. Satu-satunya perbezaan ialah, dalam Konteks Pelaksanaan Global, langkah pertama ialah mencipta objek global, manakala, dalam Konteks Pelaksanaan Fungsi, langkah pertama ialah mencipta objek parameter untuk fungsi tersebut.
Kini, persoalan timbul: bagaimanakah JavaScript mengurus Konteks Pelaksanaan ini apabila ia dicipta untuk konteks global dan setiap fungsi?
Menguruskan Konteks Pelaksanaan dengan Timbunan Pelaksanaan
Untuk mengurus konteks ini, JavaScript menggunakan struktur data yang dipanggil Timbunan Pelaksanaan. Timbunan Pelaksanaan menyimpan konteks dalam cara seperti tindanan: pertama, Konteks Pelaksanaan Global, diikuti oleh setiap Konteks Pelaksanaan Fungsi. Apabila semua konteks pelaksanaan disimpan dalam tindanan, JavaScript memprosesnya satu demi satu, bermula dari bahagian atas tindanan.
Skop dengan let dan const
Adalah penting untuk ambil perhatian bahawa apabila kami mengisytiharkan pembolehubah dengan let atau const di dalam skop global atau fungsi, pembolehubah ini tidak disimpan dalam Objek Pembolehubah semasa Fasa Penciptaan, dan ia tidak dimulakan dengan tidak ditentukan. Sebaliknya, pembolehubah ini diisytiharkan secara langsung dan diberikan nilainya dalam Fasa Pelaksanaan.
Pertimbangkan contoh kod berikut:
Contoh Kod
var a = 1; function one() { console.log(a); function two() { console.log(b); var b = 2; function three(c) { console.log(a + b + c); } three(4); } two(); } one();
Jika kami menjalankan kod ini, kami akan menghadapi ReferenceError. Ini kerana kami cuba mencetak nilai pembolehubah b sebelum mengisytiharkannya, dan kerana b diisytiharkan menggunakan const, ia berkelakuan berbeza daripada pembolehubah biasa. Pembolehubah yang diisytiharkan dengan const atau biarkan tidak disimpan dalam Objek Pembolehubah semasa Fasa Penciptaan, itulah sebabnya kami mendapat ralat semasa cuba mengaksesnya sebelum ia diberikan nilai.
Kesimpulan
Saya harap penjelasan tentang cara JavaScript berfungsi dan perkara yang berlaku semasa fasa Konteks Pelaksanaannya telah memberikan anda pemahaman yang lebih jelas. Dalam pelajaran seterusnya, kita akan meneroka topik JavaScript yang lain.
Anda boleh berhubung dengan saya di GitHub dan Linkedin.
Atas ialah kandungan terperinci Konteks Perlaksanaan JavaScript – Cara Kod JS Berjalan Di Belakang Tabir. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Penggunaan utama JavaScript dalam pembangunan web termasuk interaksi klien, pengesahan bentuk dan komunikasi tak segerak. 1) kemas kini kandungan dinamik dan interaksi pengguna melalui operasi DOM; 2) pengesahan pelanggan dijalankan sebelum pengguna mengemukakan data untuk meningkatkan pengalaman pengguna; 3) Komunikasi yang tidak bersesuaian dengan pelayan dicapai melalui teknologi Ajax.

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.

Memahami bagaimana enjin JavaScript berfungsi secara dalaman adalah penting kepada pemaju kerana ia membantu menulis kod yang lebih cekap dan memahami kesesakan prestasi dan strategi pengoptimuman. 1) aliran kerja enjin termasuk tiga peringkat: parsing, penyusun dan pelaksanaan; 2) Semasa proses pelaksanaan, enjin akan melakukan pengoptimuman dinamik, seperti cache dalam talian dan kelas tersembunyi; 3) Amalan terbaik termasuk mengelakkan pembolehubah global, mengoptimumkan gelung, menggunakan const dan membiarkan, dan mengelakkan penggunaan penutupan yang berlebihan.

Python dan JavaScript mempunyai kelebihan dan kekurangan mereka sendiri dari segi komuniti, perpustakaan dan sumber. 1) Komuniti Python mesra dan sesuai untuk pemula, tetapi sumber pembangunan depan tidak kaya dengan JavaScript. 2) Python berkuasa dalam bidang sains data dan perpustakaan pembelajaran mesin, sementara JavaScript lebih baik dalam perpustakaan pembangunan dan kerangka pembangunan depan. 3) Kedua -duanya mempunyai sumber pembelajaran yang kaya, tetapi Python sesuai untuk memulakan dengan dokumen rasmi, sementara JavaScript lebih baik dengan MDNWebDocs. Pilihan harus berdasarkan keperluan projek dan kepentingan peribadi.

Kedua -dua pilihan Python dan JavaScript dalam persekitaran pembangunan adalah penting. 1) Persekitaran pembangunan Python termasuk Pycharm, Jupyternotebook dan Anaconda, yang sesuai untuk sains data dan prototaip cepat. 2) Persekitaran pembangunan JavaScript termasuk node.js, vscode dan webpack, yang sesuai untuk pembangunan front-end dan back-end. Memilih alat yang betul mengikut keperluan projek dapat meningkatkan kecekapan pembangunan dan kadar kejayaan projek.

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.
