


Nota Kajian Javascript - Fungsi (6): Skop dan Ruang Nama_Pengetahuan Asas
Dalam pengenalan sebelum ini, kita sudah tahu bahawa Javascript tidak mempunyai skop peringkat blok, hanya skop peringkat fungsi.
function test() { // skop
for(var i = 0; i // kira
}
console.log(i); // 10
}
Juga tiada ruang nama yang jelas dalam Javascript, yang bermaksud segala-galanya ditakrifkan dalam skop global. Setiap kali pembolehubah dirujuk, Javascript akan merentasi keseluruhan skop global sehingga ia menemui pembolehubah. Jika pembolehubah tidak ditemui selepas merentasi keseluruhan skop global, ReferenceError akan dilemparkan.
Sila masukkan penerangan imej
Pembolehubah global tersirat
// skrip A
foo = '42';
// skrip B
var foo = '42'
Dua contoh di atas menghasilkan kesan yang berbeza. Yang pertama akan mentakrifkan pembolehubah foo dalam skop global, manakala yang kedua akan mentakrifkan pembolehubah foo dalam skop semasa.
Kita mesti ambil perhatian bahawa tidak menggunakan kata kunci var akan mempunyai kesan yang tidak dijangka.
// skop global
var foo = 42;
ujian fungsi() {
// skop tempatan
foo = 21;
}
ujian();
foo; // 21
Memandangkan var tidak digunakan untuk mentakrifkan pembolehubah foo dalam ujian fungsi, pembolehubah global foo di luar fungsi akan ditimpa. Walaupun ia mungkin tidak kelihatan seperti masalah besar, apabila terdapat beribu-ribu baris kod, ini boleh menjadi pepijat yang sukar untuk dijejaki.
// skop global
var item = [/* beberapa senarai */];
untuk(var i = 0; i subGelung();
}
fungsi subGelung() {
// skop subGelung
for(i = 0; i // lakukan perkara yang menakjubkan!
}
}
Dalam contoh di atas, gelung luar akan berhenti pada kali pertama ia dilaksanakan, kerana pembolehubah i di dalam fungsi gelung kecil akan menimpa pembolehubah global luar i. Kita hanya perlu menambah var di dalam fungsi untuk mengelakkan ralat ini, jadi kita tidak boleh lupa untuk menambah kata kunci var semasa mentakrifkan pembolehubah. Melainkan jika kita benar-benar mahu mempengaruhi pembolehubah global luaran.
Pembolehubah setempat
Pembolehubah setempat dalam Javascript hanya boleh dijana dalam dua cara, satu adalah untuk mengisytiharkan melalui kata kunci var, dan satu lagi adalah sebagai parameter formal fungsi.
// skop global
var foo = 1;
bar var = 2;
var i = 2;
ujian fungsi(i) {
// skop tempatan ujian fungsi
i = 5;
var foo = 3;
bar = 4;
}
ujian(10);
Pada masa ini, pembolehubah i dan foo di dalam ujian fungsi ialah pembolehubah tempatan, dan bar akan menimpa bar pembolehubah global luaran.
Mengangkat
Javascript akan menaikkan pengisytiharan pembolehubah, yang bermaksud bahawa ungkapan var dan pengisytiharan fungsi akan dinaikkan ke bahagian atas skop.
bar();
bar var = function() {};
var someValue = 42;
ujian();
ujian fungsi(data) {
Jika (salah) {
goo = 1;
} lain {
var goo = 2;
}
untuk(var i = 0; i var e = data[i];
}
}
Sebelum menjalankan kod di atas, ungkapan var dan pengisytiharan ujian fungsi akan dinaikkan pangkat ke atas, jadi program akan berjalan seperti biasa dan tiada ralat akan dilaporkan.
// pernyataan var telah dialihkan ke sini
bar var, someValue; // lalai kepada 'undefined'
// pengisytiharan fungsi juga telah dialihkan
ujian fungsi(data) {
var goo, i, e; // skop blok yang hilang memindahkannya ke sini
Jika (salah) {
goo = 1;
} lain {
goo = 2;
}
untuk(i = 0; i e = data[i];
}
}
bar(); // gagal dengan TypeError kerana bar masih 'tidak ditentukan'
someValue = 42; // tugasan tidak terjejas oleh pengangkatan
bar = function() {};
ujian();
Memandangkan Javascript tidak mempunyai skop peringkat blok, ini bukan sahaja akan meningkatkan ekspresi var, tetapi juga menjadikan struktur if kurang intuitif.
Dalam contoh di atas, walaupun nampaknya jika beroperasi pada pembolehubah global goo, sebenarnya, kerana pembolehubah goo dipromosikan, ia adalah pembolehubah tempatan yang diubah suai.
Tanpa memahami peraturan angkat, anda mungkin berfikir bahawa kod berikut akan membuang ReferenceError.
// semak sama ada SomeImportantThing telah dimulakan
jika (!Sesuatu yang Penting) {
var SomeImportantThing = {};
}
Sudah tentu kod di atas adalah bebas ralat kerana ungkapan var telah dinaikkan pangkat ke atas sebelum kod dijalankan.
var SomeImportantThing;
// kod lain mungkin memulakan SomeImportantThing di sini, atau tidak
// pastikan ia ada
jika (!Sesuatu Perkara Penting) {
SomeImportantThing = {};
}
Saya ingin mengesyorkan siaran blog @nightire Fan Ge "Memahami JavaScript (2)", yang menerangkan penambahbaikan dengan sangat teliti.
Pesanan peleraian nama
Apabila cuba mengakses pembolehubah foo dalam skop fungsi, Javascript akan melihat dalam susunan berikut:
Sama ada terdapat takrifan var foo dalam skop semasa.
Sama ada terdapat pembolehubah foo dalam parameter fungsi.
Sama ada fungsi itu sendiri dinamakan foo.
Lompat ke domain luar dan cari dari bahagian pertama.
Ruang nama
Salah satu masalah yang paling biasa ialah konflik penamaan, yang disebabkan oleh Javascript hanya mempunyai satu skop global. Tetapi masalah ini boleh diselesaikan dengan fungsi luaran tanpa nama.
(fungsi() {
// "ruang nama" yang mengandungi diri
window.foo = function() {
// penutupan terdedah
};
})(); // laksanakan fungsi dengan segera
Fungsi tanpa nama dalam contoh di atas dianggap sebagai ungkapan, jadi ia akan dilaksanakan.
( // nilaikan fungsi di dalam kurungan
fungsi() {}
) // dan kembalikan objek fungsi
() // panggil keputusan penilaian
Sudah tentu kita juga boleh memanggil ungkapan fungsi dengan cara lain, dengan struktur yang berbeza, tetapi kesan yang sama.
// Beberapa gaya lain untuk menggunakan terus
!function(){}()
function(){}()
(fungsi(){}());
// dan seterusnya...
Ringkasan
Adalah disyorkan agar anda menggunakan fungsi luaran tanpa nama untuk merangkum kod ke dalam ruang Ini bukan sahaja dapat menyelesaikan konflik ruang nama, tetapi juga memudahkan pemodulatan program.
Selain itu, menggunakan pembolehubah global bukanlah amalan yang baik, kerana ia memerlukan kos penyelenggaraan dan terdedah kepada ralat.
Jenis ruang nama, fungsi, pembolehubah, templat, dll. semuanya milik entiti.
Perkara utama yang mempunyai persamaan entiti ialah mereka boleh mempunyai nama. (Selain itu, label juga boleh mempunyai nama, tetapi ia bukan entiti.)
Skop ruang nama ialah istilah umum untuk jenis skop, disandingkan dengan skop blok, skop kelas, skop prototaip fungsi dan skop fungsi (hanya sah untuk label). Nama yang diisytiharkan dalam ruang nama adalah dalam skop ruang nama. Nama global dianggap berada dalam skop ruang nama global yang tersirat.
Peranan ruang nama sememangnya skop, tetapi ia berbeza daripada skop ringkas Anda boleh mengisytiharkan ruang nama yang sama berbilang kali di beberapa tempat, tetapi kandungannya tidak boleh ditakrifkan semula menjadi satu nama. Ruang, sama seperti std, takrifan makro di mana-mana

Perbezaan utama antara Python dan JavaScript ialah sistem jenis dan senario aplikasi. 1. Python menggunakan jenis dinamik, sesuai untuk pengkomputeran saintifik dan analisis data. 2. JavaScript mengamalkan jenis yang lemah dan digunakan secara meluas dalam pembangunan depan dan stack penuh. Kedua -duanya mempunyai kelebihan mereka sendiri dalam pengaturcaraan dan pengoptimuman prestasi yang tidak segerak, dan harus diputuskan mengikut keperluan projek ketika memilih.

Sama ada untuk memilih Python atau JavaScript bergantung kepada jenis projek: 1) Pilih Python untuk Sains Data dan Tugas Automasi; 2) Pilih JavaScript untuk pembangunan front-end dan penuh. Python disukai untuk perpustakaannya yang kuat dalam pemprosesan data dan automasi, sementara JavaScript sangat diperlukan untuk kelebihannya dalam interaksi web dan pembangunan stack penuh.

Python dan JavaScript masing -masing mempunyai kelebihan mereka sendiri, dan pilihan bergantung kepada keperluan projek dan keutamaan peribadi. 1. Python mudah dipelajari, dengan sintaks ringkas, sesuai untuk sains data dan pembangunan back-end, tetapi mempunyai kelajuan pelaksanaan yang perlahan. 2. JavaScript berada di mana-mana dalam pembangunan front-end dan mempunyai keupayaan pengaturcaraan tak segerak yang kuat. Node.js menjadikannya sesuai untuk pembangunan penuh, tetapi sintaks mungkin rumit dan rawan kesilapan.

Javascriptisnotbuiltoncorc; it'saninterpretedlanguagethatrunsonenginesoftenwritteninc .1) javascriptwasdesignedasalightweight, interpratedlanguageforwebbrowsers.2)

JavaScript boleh digunakan untuk pembangunan front-end dan back-end. Bahagian depan meningkatkan pengalaman pengguna melalui operasi DOM, dan back-end mengendalikan tugas pelayan melalui Node.js. 1. Contoh front-end: Tukar kandungan teks laman web. 2. Contoh backend: Buat pelayan Node.js.

Memilih Python atau JavaScript harus berdasarkan perkembangan kerjaya, keluk pembelajaran dan ekosistem: 1) Pembangunan Kerjaya: Python sesuai untuk sains data dan pembangunan back-end, sementara JavaScript sesuai untuk pembangunan depan dan penuh. 2) Kurva Pembelajaran: Sintaks Python adalah ringkas dan sesuai untuk pemula; Sintaks JavaScript adalah fleksibel. 3) Ekosistem: Python mempunyai perpustakaan pengkomputeran saintifik yang kaya, dan JavaScript mempunyai rangka kerja front-end yang kuat.

Kuasa rangka kerja JavaScript terletak pada pembangunan yang memudahkan, meningkatkan pengalaman pengguna dan prestasi aplikasi. Apabila memilih rangka kerja, pertimbangkan: 1.

Pengenalan Saya tahu anda mungkin merasa pelik, apa sebenarnya yang perlu dilakukan oleh JavaScript, C dan penyemak imbas? Mereka seolah -olah tidak berkaitan, tetapi sebenarnya, mereka memainkan peranan yang sangat penting dalam pembangunan web moden. Hari ini kita akan membincangkan hubungan rapat antara ketiga -tiga ini. Melalui artikel ini, anda akan mempelajari bagaimana JavaScript berjalan dalam penyemak imbas, peranan C dalam enjin pelayar, dan bagaimana mereka bekerjasama untuk memacu rendering dan interaksi laman web. Kita semua tahu hubungan antara JavaScript dan penyemak imbas. JavaScript adalah bahasa utama pembangunan front-end. Ia berjalan secara langsung di penyemak imbas, menjadikan laman web jelas dan menarik. Adakah anda pernah tertanya -tanya mengapa Javascr


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

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

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.

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod
