


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!

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Artikel membincangkan membuat, menerbitkan, dan mengekalkan perpustakaan JavaScript, memberi tumpuan kepada perancangan, pembangunan, ujian, dokumentasi, dan strategi promosi.

Artikel ini membincangkan strategi untuk mengoptimumkan prestasi JavaScript dalam pelayar, memberi tumpuan kepada mengurangkan masa pelaksanaan dan meminimumkan kesan pada kelajuan beban halaman.

Artikel ini membincangkan debugging JavaScript yang berkesan menggunakan alat pemaju pelayar, memberi tumpuan kepada menetapkan titik putus, menggunakan konsol, dan menganalisis prestasi.

Artikel ini akan membimbing anda untuk membuat karusel gambar mudah menggunakan perpustakaan jQuery. Kami akan menggunakan perpustakaan BXSlider, yang dibina di atas jQuery dan menyediakan banyak pilihan konfigurasi untuk menubuhkan karusel. Pada masa kini, Gambar Carousel telah menjadi ciri yang mesti ada di laman web - satu gambar lebih baik daripada seribu perkataan! Selepas membuat keputusan untuk menggunakan karusel gambar, soalan seterusnya adalah bagaimana untuk menciptanya. Pertama, anda perlu mengumpul gambar-gambar resolusi tinggi yang berkualiti tinggi. Seterusnya, anda perlu membuat karusel gambar menggunakan HTML dan beberapa kod JavaScript. Terdapat banyak perpustakaan di web yang dapat membantu anda membuat karusel dengan cara yang berbeza. Kami akan menggunakan Perpustakaan BXSlider Sumber Terbuka. Perpustakaan BXSlider menyokong reka bentuk responsif, jadi karusel yang dibina dengan perpustakaan ini dapat disesuaikan dengan mana -mana

Bawa kesan filem matriks ke halaman anda! Ini adalah plugin jQuery yang sejuk berdasarkan filem terkenal "The Matrix". Plugin mensimulasikan kesan aksara hijau klasik dalam filem, dan hanya pilih gambar dan plugin akan mengubahnya menjadi gambar gaya matriks yang diisi dengan aksara angka. Datang dan cuba, sangat menarik! Bagaimana ia berfungsi Plugin memuat imej ke kanvas dan membaca nilai piksel dan warna: data = ctx.getimagedata (x, y, settings.grainsize, settings.grainsize) .data Plugin dengan bijak membaca kawasan segi empat tepat gambar dan menggunakan jQuery untuk mengira warna purata setiap kawasan. Kemudian, gunakan

Artikel ini menerangkan cara menggunakan peta sumber untuk debug JavaScript minifikasi dengan memetakannya kembali ke kod asal. Ia membincangkan membolehkan peta sumber, menetapkan titik putus, dan menggunakan alat seperti Chrome Devtools dan Webpack.


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

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.