Rumah hujung hadapan web tutorial js Analisis skop penuh pembolehubah JavaScript_Pengetahuan asas

Analisis skop penuh pembolehubah JavaScript_Pengetahuan asas

May 16, 2016 pm 03:45 PM
javascript Skop pembolehubah

Skop pembolehubah ialah kawasan dalam program di mana pembolehubah ditakrifkan.
Mari lihat contoh dahulu:

/* Kod 1 */

var scope = "global ";
function checkScope() {
 var scope = "local ";
 function childCheck() {
  var scope = "childLocal ";
  document.write(scope);
 }
 function childUndefined() {
  document.write(scope);
  var scope;
 }
 function childOverride() {
  scope = "childOverride ";
  document.write(scope);
 }
 document.write(scope); //输出"local"
 childCheck();   //输出"childLocal"
 childUndefined();  //输出"undefined"
 childOverride();  //输出"childOverride"
 document.write(scope); //输出"childOverride"
}
checkScope();    //输出"local childLocal undefinedchildOverride childOverride"
document.write(scope);  //输出"global "
Salin selepas log masuk

Skop global dan skop tempatan
Pembolehubah global mempunyai skop global dan ditakrifkan di mana-mana dalam Javascript pembolehubah yang diisytiharkan di dalam fungsi adalah pembolehubah tempatan, dan skopnya adalah setempat dan hanya ditakrifkan di dalam badan fungsi. Output berikut seharusnya tidak mengejutkan pembaca.
/* Kod 2 */

var scope = "global";
function checkScope() {
 var scope = "local";
 document.write(scope);
}
checkScope();   //输出"local"
document.write(scope); //输出"global"
Salin selepas log masuk

Anda boleh menggunakan pembolehubah dalam skop pembolehubah global tanpa pernyataan var, tetapi anda mesti menggunakan penyataan var apabila mengisytiharkan pembolehubah tempatan, jika tidak, ia akan dianggap sebagai rujukan kepada pembolehubah global. Lihat kod di bawah:
/* Kod 3 */

var scope = "global";
function checkScope() {
 scope = "local";
 document.write(scope);
}
checkScope();   //输出"local"
document.write(scope); //输出"local"
Salin selepas log masuk

Tiada skop blok
Javascript tidak mempunyai skop peringkat blok dan pembolehubah yang diisytiharkan dalam fungsi ditentukan di seluruh fungsi. Kod berikut mungkin mengejutkan pembaca yang tidak dikenali:
/* Kod 4 */

var scope = "global";
function checkScope() {
 document.write(scope); //语句4.1
 var scope = "local"; //语句4.2
 document.write(scope);
}
checkScope();   //输出"undefinedlocal"
Salin selepas log masuk

Memandangkan pembolehubah yang diisytiharkan dalam pernyataan 4.1 (var skop = "tempatan";) adalah sah dalam keseluruhan skop fungsi checkScope, apabila pernyataan 4.2 (document.write(skop);) dilaksanakan, skop merujuk kepada pembolehubah tempatan. Pada masa ini, skop pembolehubah tempatan belum ditentukan, jadi "tidak ditentukan" ialah output. Oleh itu amalan pengaturcaraan yang baik adalah mengumpulkan semua pengisytiharan pembolehubah pada permulaan fungsi.

Setelah memahami kandungan di atas, pembaca tidak boleh keliru jika melihat Kod 1.
Pembolehubah atribut objek
Pembolehubah atribut objek agak mudah difahami Pembaca yang melihat kod berikut tidak boleh keliru.
/* Kod 5 */

var scope = "global ";
var obj = new Object();
obj.scope = "object ";
obj.checkScope = function () {
 var scope = "loacl ";
 document.write(scope);   //输出"loacl"
 document.write(this.scope);  //输出"object"
 document.write(window.scope); //输出"global"
}
obj.checkScope(); //输出"loacl object global"
Salin selepas log masuk

Skop yang dipanggil merujuk kepada julat sah pembolehubah ini dalam blok kod. Jika anda tidak memahami skop JavaScript, mungkin sukar untuk menyahpepijat kod anda.

Dalam fungsi, jika anda menggunakan var untuk mengisytiharkan pembolehubah, skop pembolehubah adalah terhad kepada bahagian dalam fungsi dan kod di luar fungsi tidak boleh mengakses pembolehubah. Jika anda mengisytiharkan fungsi dalam fungsi ini, fungsi dalaman juga boleh mengakses pembolehubah ini.

Sebaliknya, jika var tidak digunakan semasa mengisytiharkan pembolehubah, maka skop pembolehubah ini tidak terhad kepada fungsi ini. Enjin JavaScript akan menyemak sama ada pembolehubah telah ditakrifkan dalam skop global. Jika pembolehubah belum ditakrifkan, ia akan ditakrifkan sebagai pembolehubah global.

Fungsi boleh mengakses pembolehubah dalam skop yang sama:

var foo = 'hello';

var sayHello = function() {
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // also logs 'hello'

Salin selepas log masuk
Salin selepas log masuk

Kod di luar skop pembolehubah tidak boleh mengakses pembolehubah:

var sayHello = function() {
 var foo = 'hello';
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // doesn't log anything

Salin selepas log masuk
Salin selepas log masuk

Jangan gunakan pembolehubah dengan nama yang sama dalam skop, tetapi mempunyai nilai yang berbeza:

var foo = 'world';

var sayHello = function() {
 var foo = 'hello';
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // logs 'world'

Salin selepas log masuk
Salin selepas log masuk

Selepas fungsi ditakrifkan, anda boleh melihat perubahan dalam nilai pembolehubah ​​​​dalam fungsi:

var myFunction = function() {
 var foo = 'hello';

 var myFn = function() {
  console.log(foo);
 };

 foo = 'world';

 return myFn;
};

var f = myFunction();
f(); // logs 'world' -- haha

Salin selepas log masuk
Salin selepas log masuk

Skop juga merentasi — penutupan

// 一个自执行的匿名函数
(function() {
 var baz = 1;
 var bim = function() { alert(baz); };
 bar = function() { alert(baz); };
})();

console.log(baz); // 在函数外面不能访问 baz

bar(); // 声明 bar 的时候并没有用 var
  // 所以 bar 是一个全局变量; 但是,
  // bar 和 baz 在相同的作用域内被定义,
  // 所以 bar 可以访问 baz
  // 其实 bar 是个闭包函数

bim(); // bim 的作用域只限于匿名函数内部,
  // 所以这里不能调用
Salin selepas log masuk

Komprehensif

Skop yang dipanggil merujuk kepada julat sah pembolehubah ini dalam blok kod. Jika anda tidak memahami skop JavaScript, mungkin sukar untuk menyahpepijat kod anda.

Dalam fungsi, jika anda menggunakan var untuk mengisytiharkan pembolehubah, skop pembolehubah adalah terhad kepada bahagian dalam fungsi dan kod di luar fungsi tidak boleh mengakses pembolehubah. Jika anda mengisytiharkan fungsi dalam fungsi ini, fungsi dalaman juga boleh mengakses pembolehubah ini.

Sebaliknya, jika var tidak digunakan semasa mengisytiharkan pembolehubah, maka skop pembolehubah ini tidak terhad kepada fungsi ini. Enjin JavaScript akan menyemak sama ada pembolehubah telah ditakrifkan dalam skop global. Jika pembolehubah belum ditakrifkan, ia akan ditakrifkan sebagai pembolehubah global.

Fungsi boleh mengakses pembolehubah dalam skop yang sama:

var foo = 'hello';

var sayHello = function() {
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // also logs 'hello'

Salin selepas log masuk
Salin selepas log masuk

Kod di luar skop pembolehubah tidak boleh mengakses pembolehubah:

var sayHello = function() {
 var foo = 'hello';
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // doesn't log anything

Salin selepas log masuk
Salin selepas log masuk

Jangan gunakan pembolehubah dengan nama yang sama dalam skop, tetapi mempunyai nilai yang berbeza:

var foo = 'world';

var sayHello = function() {
 var foo = 'hello';
 console.log(foo);
};

sayHello();   // logs 'hello'
console.log(foo); // logs 'world'

Salin selepas log masuk
Salin selepas log masuk

Selepas fungsi ditakrifkan, anda boleh melihat perubahan dalam nilai pembolehubah ​​​​dalam fungsi:

var myFunction = function() {
 var foo = 'hello';

 var myFn = function() {
  console.log(foo);
 };

 foo = 'world';

 return myFn;
};

var f = myFunction();
f(); // logs 'world' -- haha

Salin selepas log masuk
Salin selepas log masuk

Skop juga merentasi — penutupan

// 一个自执行的匿名函数
(function() {
 var baz = 1;
 var bim = function() { alert(baz); };
 bar = function() { alert(baz); };
})();

console.log(baz); // 在函数外面不能访问 baz

bar(); // 声明 bar 的时候并没有用 var
  // 所以 bar 是一个全局变量; 但是,
  // bar 和 baz 在相同的作用域内被定义,
  // 所以 bar 可以访问 baz
  // 其实 bar 是个闭包函数

bim(); // bim 的作用域只限于匿名函数内部,
  // 所以这里不能调用

Salin selepas log masuk

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penggunaan typedef struct dalam bahasa c Penggunaan typedef struct dalam bahasa c May 09, 2024 am 10:15 AM

typedef struct digunakan dalam bahasa C untuk mencipta alias jenis struktur untuk memudahkan penggunaan struktur. Ia alias jenis data baharu kepada struktur sedia ada dengan menentukan alias struktur. Faedah termasuk kebolehbacaan yang dipertingkatkan, penggunaan semula kod dan pemeriksaan jenis. Nota: Struktur mesti ditakrifkan sebelum menggunakan alias itu mestilah unik dalam program dan hanya sah dalam skop di mana ia diisytiharkan.

Bagaimana untuk menyelesaikan pembolehubah yang diharapkan dalam java Bagaimana untuk menyelesaikan pembolehubah yang diharapkan dalam java May 07, 2024 am 02:48 AM

Pengecualian nilai jangkaan pembolehubah dalam Java boleh diselesaikan dengan: memulakan pembolehubah menggunakan nilai nol menggunakan semakan dan tugasan;

Kelebihan dan kekurangan penutupan dalam js Kelebihan dan kekurangan penutupan dalam js May 10, 2024 am 04:39 AM

Kelebihan penutupan JavaScript termasuk mengekalkan skop pembolehubah, membolehkan kod modular, pelaksanaan tertunda, dan keburukan pengendalian peristiwa termasuk kebocoran memori, peningkatan kerumitan, overhed prestasi dan kesan rantaian skop.

Apa yang termasuk bermakna dalam c++ Apa yang termasuk bermakna dalam c++ May 09, 2024 am 01:45 AM

Arahan prapemproses #include dalam C++ memasukkan kandungan fail sumber luaran ke dalam fail sumber semasa, menyalin kandungannya ke lokasi yang sepadan dalam fail sumber semasa. Digunakan terutamanya untuk memasukkan fail pengepala yang mengandungi pengisytiharan yang diperlukan dalam kod, seperti #include <iostream> untuk memasukkan fungsi input/output standard.

Petunjuk pintar C++: analisis komprehensif kitaran hayat mereka Petunjuk pintar C++: analisis komprehensif kitaran hayat mereka May 09, 2024 am 11:06 AM

Kitaran hayat penunjuk pintar C++: Penciptaan: Penunjuk pintar dicipta apabila memori diperuntukkan. Pemindahan pemilikan: Pindahkan pemilikan melalui operasi pemindahan. Keluaran: Memori dikeluarkan apabila penunjuk pintar keluar dari skop atau dikeluarkan secara eksplisit. Pemusnahan objek: Apabila objek runcing dimusnahkan, penunjuk pintar menjadi penunjuk tidak sah.

Terdapat beberapa situasi di mana ini dalam js menunjuk ke Terdapat beberapa situasi di mana ini dalam js menunjuk ke May 06, 2024 pm 02:03 PM

Dalam JavaScript, jenis penunjuk ini termasuk: 1. Objek global 2. Panggilan fungsi; 4. Pengendali acara; Selain itu, penunjuk kepada ini boleh ditetapkan secara eksplisit menggunakan kaedah bind(), call(), dan apply().

Bolehkah definisi fungsi dan panggilan dalam C++ bersarang? Bolehkah definisi fungsi dan panggilan dalam C++ bersarang? May 06, 2024 pm 06:36 PM

boleh. C++ membenarkan definisi dan panggilan fungsi bersarang. Fungsi luaran boleh menentukan fungsi terbina dalam, dan fungsi dalaman boleh dipanggil terus dalam skop. Fungsi bersarang meningkatkan enkapsulasi, kebolehgunaan semula dan kawalan skop. Walau bagaimanapun, fungsi dalaman tidak boleh mengakses pembolehubah tempatan fungsi luaran secara langsung, dan jenis nilai pulangan mesti konsisten dengan pengisytiharan fungsi luaran Fungsi dalaman tidak boleh rekursif sendiri.

Perbezaan antara let dan var dalam vue Perbezaan antara let dan var dalam vue May 08, 2024 pm 04:21 PM

Dalam Vue, terdapat perbezaan dalam skop apabila mengisytiharkan pembolehubah antara let dan var: Skop: var mempunyai skop global dan let mempunyai skop peringkat blok. Skop peringkat blok: var tidak mencipta skop peringkat blok, mari buat skop peringkat blok. Pengisytiharan Semula: var membenarkan pembolehubah diisytiharkan semula dalam skop yang sama, jangan biarkan.

See all articles