Rumah hujung hadapan web tutorial js Analisis mendalam tentang perbezaan antara var, let dan const

Analisis mendalam tentang perbezaan antara var, let dan const

Feb 20, 2024 pm 06:27 PM
Skop kata kunci var biarkan kata kunci kata kunci const

Analisis mendalam tentang perbezaan antara var, let dan const

Analisis mendalam tentang perbezaan antara var, let dan const memerlukan contoh kod khusus

Dalam JavaScript, pengisytiharan pembolehubah ialah operasi yang sangat biasa. Sebelum ES5, pembangun menggunakan kata kunci var untuk mengisytiharkan pembolehubah. Walau bagaimanapun, ES6 memperkenalkan dua kata kunci baharu, let dan const, yang menyediakan pengurusan pembolehubah dan kawalan skop yang lebih baik. Dalam artikel ini, kami akan menyelami perbezaan antara var, let dan const serta memberikan contoh kod yang sepadan untuk membantu pemahaman.

1. Skop

Pembolehubah yang diisytiharkan dengan kata kunci var mempunyai skop peringkat fungsi. Ini bermakna pembolehubah boleh dilihat di dalam fungsi di mana ia diisytiharkan, tetapi tidak di luar fungsi. Selain itu, pembolehubah yang diisytiharkan menggunakan var juga mempunyai ciri promosi pembolehubah, yang boleh digunakan sebelum pengisytiharan. Kata kunci

let dan const mempunyai skop peringkat blok. Skop peringkat blok bermakna skop pemboleh ubah yang boleh dilihat dihadkan kepada kurungan kerinting {}, seperti pernyataan if, untuk gelung, dsb. Pembolehubah yang diisytiharkan dengan let dan const tidak kelihatan sehingga diisytiharkan dan tidak dinaikkan ke bahagian atas skop semasa.

Kod sampel adalah seperti berikut:

function example() {
  var varVariable = 'var example';
  let letVariable = 'let example';
  
  if (true) {
    console.log(varVariable); // 输出:var example
    console.log(letVariable); // 报错:ReferenceError: letVariable is not defined
    
    var varInner = 'var inner';
    let letInner = 'let inner';
  }
  
  console.log(varInner); // 输出:var inner
  console.log(letInner); // 报错:ReferenceError: letInner is not defined
}
Salin selepas log masuk

2. Pengisytiharan Semula

Pembolehubah yang diisytiharkan menggunakan kata kunci var boleh diisytiharkan semula tanpa ralat. Ini boleh menyebabkan masalah yang tidak dijangka, terutamanya jika nama pembolehubah yang sama diisytiharkan dalam berbilang fail.

Pembolehubah yang diisytiharkan dengan kata kunci let juga boleh diisytiharkan semula, tetapi ralat akan dilaporkan. Ini membantu kami mengelakkan pengisytiharan semula pembolehubah dengan nama yang sama secara tidak sengaja.

Pembolehubah yang diisytiharkan oleh kata kunci const adalah pemalar Setelah ditetapkan, ia tidak boleh ditukar dan tidak boleh diisytiharkan semula. Percubaan untuk mengisytiharkan semula pembolehubah const akan menimbulkan SyntaxError.

Kod sampel adalah seperti berikut:

var varVariable = 'var example';
var varVariable = 'var redeclared example'; // 重新声明,不报错
console.log(varVariable); // 输出:var redeclared example

let letVariable = 'let example';
let letVariable = 'let redeclared example'; // 重新声明,报错:SyntaxError: Identifier 'letVariable' has already been declared

const constVariable = 'const example';
const constVariable = 'const redeclared example'; // 重新声明,报错:SyntaxError: Identifier 'constVariable' has already been declared
Salin selepas log masuk

3. Pemboleh ubah promosi

Pembolehubah yang diisytiharkan menggunakan kata kunci var mempunyai ciri promosi berubah. Ini bermakna pembolehubah boleh digunakan sebelum ia diisytiharkan, dan skopnya ialah keseluruhan fungsi.

Pembolehubah yang diisytiharkan menggunakan kata kunci let dan const tidak akan dipromosikan. Ini bermakna bahawa menggunakan pembolehubah sebelum ia diisytiharkan akan menimbulkan ReferenceError.

Kod sampel adalah seperti berikut:

console.log(varVariable); // 输出:undefined
console.log(letVariable); // 报错:ReferenceError: Cannot access 'letVariable' before initialization
console.log(constVariable); // 报错:ReferenceError: Cannot access 'constVariable' before initialization

var varVariable = 'var example';
let letVariable = 'let example';
const constVariable = 'const example';
Salin selepas log masuk

4. Skop global

Pembolehubah global yang diisytiharkan menggunakan kata kunci var akan terikat pada objek global (tetingkap atau global). Ini bermakna varVariable boleh diakses melalui window.varVariable dalam penyemak imbas.

Pembolehubah yang diisytiharkan menggunakan kata kunci let dan const tidak akan terikat pada objek global, ia hanya boleh dilihat dalam skop yang diisytiharkan.

Kod sampel adalah seperti berikut:

var varVariable = 'var example';
let letVariable = 'let example';
const constVariable = 'const example';

console.log(window.varVariable); // 输出:var example
console.log(window.letVariable); // 输出:undefined
console.log(window.constVariable); // 输出:undefined
Salin selepas log masuk

Ringkasan:

var, let dan const ialah cara biasa untuk mengisytiharkan pembolehubah dalam JavaScript, dan terdapat beberapa perbezaan penting di antara mereka. Menggunakan let dan const mengelakkan masalah promosi berubah-ubah dan pengisytiharan semula, dan menyediakan kawalan skop yang lebih baik, menjadikan kod lebih dipercayai dan boleh diselenggara. Dalam pembangunan sebenar, adalah disyorkan untuk menggunakan let dan const dan bukannya var untuk meningkatkan kualiti dan kebolehbacaan kod.

Atas ialah kandungan terperinci Analisis mendalam tentang perbezaan antara var, let dan const. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu 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;

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.

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.

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.

Bagaimanakah penutupan dilaksanakan di Jawa? Bagaimanakah penutupan dilaksanakan di Jawa? May 03, 2024 pm 12:48 PM

Penutupan dalam Java membenarkan fungsi dalaman mengakses pembolehubah skop luar walaupun fungsi luar telah keluar. Dilaksanakan melalui kelas dalaman tanpa nama, kelas dalam memegang rujukan kepada kelas luar dan memastikan pembolehubah luar aktif. Penutupan meningkatkan fleksibiliti kod, tetapi anda perlu sedar tentang risiko kebocoran memori kerana rujukan kepada pembolehubah luaran oleh kelas dalaman tanpa nama memastikan pembolehubah tersebut hidup.

See all articles