ES6 - Değişkenler
Bir variable, tanımı gereği, değerleri depolayan “bellekte adlandırılmış bir alan” dır. Başka bir deyişle, bir programdaki değerler için bir kap görevi görür. Değişken isimler deniridentifiers. Bir tanımlayıcı için adlandırma kuralları aşağıdadır -
Tanımlayıcılar anahtar kelime olamaz.
Tanımlayıcılar harf ve sayı içerebilir.
Tanımlayıcılar, alt çizgi (_) ve dolar ($) işareti dışında boşluk ve özel karakterler içeremez.
Değişken isimleri bir sayıyla başlayamaz.
Tür Sözdizimi
Kullanılmadan önce bir değişken bildirilmelidir. ES5 sözdizimi,varaynı şeyi başarmak için anahtar kelime. Bir değişkeni bildirmek için ES5 sözdizimi aşağıdaki gibidir.
//Declaration using var keyword
var variable_name
ES6, aşağıdaki değişken bildirim sözdizimini sunar -
- Let kullanarak.
- Sabit kullanarak.
Variable initializationdeğişkende bir değer saklama sürecini ifade eder. Bir değişken, bildirimi sırasında veya daha sonraki bir zamanda başlatılabilir.
Bir değişkeni bildirmek ve başlatmak için geleneksel ES5 türü sözdizimi aşağıdaki gibidir -
//Declaration using var keyword
var variable_name = value
Örnek: Değişkenleri Kullanma
var name = "Tom"
console.log("The value in the variable is: "+name)
Yukarıdaki örnek bir değişken bildirir ve değerini yazdırır.
Başarılı yürütmede aşağıdaki çıktı görüntülenir.
The value in the variable is Tom
JavaScript ve Dinamik Yazma
JavaScript, yazılmamış bir dildir. Bu, bir JavaScript değişkeninin herhangi bir veri türünün değerini tutabileceği anlamına gelir. Diğer birçok dilden farklı olarak, değişken bildirimi sırasında JavaScript'e değişkenin ne tür bir değer tutacağını söylemeniz gerekmez. Bir değişkenin değer türü, bir programın yürütülmesi sırasında değişebilir ve JavaScript bununla otomatik olarak ilgilenir. Bu özellik olarak adlandırılırdynamic typing.
JavaScriptVariable Kapsam
Bir değişkenin kapsamı, içinde tanımlandığı programınızın bölgesidir. Geleneksel olarak, JavaScript yalnızca iki kapsam tanımlar: küresel ve yerel.
Global Scope - Genel kapsamı olan bir değişkene JavaScript kodunun herhangi bir bölümünden erişilebilir.
Local Scope - Yerel kapsamı olan bir değişkene, bildirildiği bir fonksiyonun içinden erişilebilir.
Örnek: Global ve Yerel Değişken
Aşağıdaki örnek, ada göre iki değişken bildirir num - biri işlevin dışında (genel kapsam) ve diğeri işlev içinde (yerel kapsam).
var num = 10
function test() {
var num = 100
console.log("value of num in test() "+num)
}
console.log("value of num outside test() "+num)
test()
Değişken, işlev içinde başvurulduğunda yerel kapsamlı değişkenin değerini görüntüler. Ancak değişkennum işlevin dışından erişildiğinde, genel kapsamlı örneği döndürür.
Başarılı yürütmede aşağıdaki çıktı görüntülenir.
value of num outside test() 10
value of num in test() 100
ES6, yeni bir değişken kapsamı tanımlar - Blok kapsamı.
Let ve Block Kapsamı
Blok kapsamı, bir değişkenin bildirildiği bloğa erişimini kısıtlar. varanahtar kelime, değişkene bir işlev kapsamı atar. Var anahtar kelimesinin aksine,let anahtar sözcük, komut dosyasının değişkene erişimi en yakın çevreleyen bloğa kısıtlamasına izin verir.
"use strict"
function test() {
var num = 100
console.log("value of num in test() "+num) {
console.log("Inner Block begins")
let num = 200
console.log("value of num : "+num)
}
}
test()
Komut dosyası bir değişken bildiriyor numbir işlevin yerel kapsamı içinde ve let anahtar sözcüğünü kullanarak bir blok içinde yeniden bildirir. Yerel kapsamlı değişkenin değeri, değişkene iç bloğun dışından erişildiğinde yazdırılırken, blok kapsamlı değişken iç blok içinde belirtilir.
Note - Katı mod, kısıtlı bir JavaScript varyantını seçmenin bir yoludur.
Başarılı yürütmede aşağıdaki çıktı görüntülenir.
value of num in test() 100
Inner Block begins
value of num : 200
Örnek: let v / s var
var no = 10;
var no = 20;
console.log(no);
Yukarıdaki kod başarılı bir şekilde yürütüldüğünde aşağıdaki çıktı görüntülenir.
20
Aynı kodu kullanarak yeniden yazalım. let anahtar kelime.
let no = 10;
let no = 20;
console.log(no);
Yukarıdaki kod bir hata oluşturacaktır: Tanımlayıcı 'hayır' zaten bildirilmiştir. Let anahtar sözcüğü kullanılarak bildirilen herhangi bir değişkene blok kapsamı atanır.
izin ver ve seviye güvenliği engelle
Bir ilan etmeye çalışırsak letaynı blok içinde iki kez değişken olursa, bir hata atar. Aşağıdaki örneği düşünün -
<script>
let balance = 5000 // number type
console.log(typeof balance)
let balance = {message:"hello"} // changing number to object type
console.log(typeof balance)
</script>
Yukarıdaki kod aşağıdaki hataya neden olacaktır -
Uncaught SyntaxError: Identifier 'balance' has already been declared
izin ve birden çok blok
Ancak aynı let değişkeni, herhangi bir sözdizimi hatası olmaksızın farklı blok seviyesi kapsamlarında kullanılabilir.
Misal
<script>
let count = 100
for (let count = 1;count <= 10;count++){
//inside for loop brackets ,count value starts from 1
console.log("count value inside loop is ",count);
}
//outside for loop brackets ,count value is 100
console.log("count value after loop is",count);
if(count == 100){
//inside if brackets ,count value is 50
let count = 50;
console.log("count inside if block",count);
}
console.log(count);
</script>
Yukarıdaki kodun çıktısı aşağıdaki gibi olacaktır -
count value inside loop is 1
count value inside loop is 2
count value inside loop is 3
count value inside loop is 4
count value inside loop is 5
count value inside loop is 6
count value inside loop is 7
count value inside loop is 8
count value inside loop is 9
count value inside loop is 10
count value after loop is 100
count inside if block 50
100
Sabit
constbildirim, bir değere salt okunur bir başvuru oluşturur. Bu, tuttuğu değerin değişmez olduğu anlamına gelmez, sadece değişken tanımlayıcısının yeniden atanamayacağı anlamına gelir. Sabitler, let ifadesi kullanılarak tanımlanan değişkenlere çok benzer şekilde blok kapsamlıdır. Bir sabitin değeri yeniden atama yoluyla değiştirilemez ve yeniden beyan edilemez.
Aşağıdaki kurallar, kullanılarak bildirilen bir değişken için doğrudur const anahtar kelime -
- Sabitler yeniden bir değer atanamaz.
- Bir sabit yeniden beyan edilemez.
- Bir sabit, bir başlatıcı gerektirir. Bu, sabitlerin bildirimi sırasında başlatılması gerektiği anlamına gelir.
- A'ya atanan değer const değişken değiştirilebilir.
Misal
const x = 10
x = 12 // will result in an error!!
Yukarıdaki kod, sabitlere bir değer atanamayacağı için bir hata döndürecektir. Sabitler değişkeni değişmezdir.
Sabitler Değişmezdir
Kullanılarak bildirilen değişkenlerin aksine let anahtar kelime constantsdeğişmez. Bu, değerinin değiştirilemeyeceği anlamına gelir. Örneğin, sabit değişkenin değerini değiştirmeye çalışırsak, bir hata görüntülenecektir.
<script>
let income = 100000
const INTEREST_RATE = 0.08
income += 50000 // mutable
console.log("changed income value is ",income)
INTEREST_RATE += 0.01
console.log("changed rate is ",INTEREST_RATE) //Error: not mutable
</script>
Yukarıdaki kodun çıktısı aşağıdaki gibi olacaktır -
changed income value is 150000
Uncaught TypeError: Assignment to constant variable
const ve diziler
Aşağıdaki örnek, değişmez bir dizinin nasıl oluşturulacağını gösterir. Diziye yeni elemanlar eklenebilir. Ancak, diziyi yeniden başlatmak, aşağıda gösterildiği gibi bir hatayla sonuçlanacaktır -
<script>
const DEPT_NOS = [10,20,30,50]
DEPT_NOS.push(40)
console.log('dept numbers is ',DEPT_NOS)
const EMP_IDS = [1001,1002,1003]
console.log('employee ids',EMP_IDS)
//re assigning variable employee ids
EMP_IDS = [2001,2002,2003]
console.log('employee ids after changing',EMP_IDS)
</script>
Yukarıdaki kodun çıktısı aşağıda gösterildiği gibi olacaktır -
dept numbers is (5) [10, 20, 30, 50, 40]
employee ids (3) [1001, 1002, 1003]
Uncaught TypeError: Assignment to constant variable.
Var anahtar sözcüğü
ES6'dan önce, varanahtar kelime, JavaScript'te bir değişken bildirmek için kullanıldı. Kullanılarak bildirilen değişkenlervarblok düzeyi kapsamını desteklemez. Bu, bir değişkenin bir döngüde bildirilmesi veyaif block döngünün dışından erişilebilir veya if block. Bunun nedeni,var anahtar kelime desteği kaldırma.
var ve kaldırma
Variable hoistingbir değişkenin bir JavaScript programında, bildirilmeden önce kullanılmasına izin verir. Bu tür değişkenler,undefinedvarsayılan olarak. JavaScript çalışma zamanı, değişken bildirimlerini tarar ve bunları işlevin veya komut dosyasının en üstüne yerleştirir. İle bildirilen değişkenlervaranahtar kelime en üste çıkar. Aşağıdaki örneği düşünün -
<script>
variable company is hoisted to top , var company = undefined
console.log(company); // using variable before declaring
var company = "TutorialsPoint"; // declare and initialized here
console.log(company);
</script>
Yukarıdaki kodun çıktısı aşağıda gösterildiği gibi olacaktır -
undefined
TutorialsPoint
var ve blok kapsamı
block scopebir değişkenin bildirildiği bloğa erişimini kısıtlar. varanahtar kelime, değişkene bir işlev kapsamı atar. Kullanılarak bildirilen değişkenlervaranahtar kelimenin bir blok kapsamı yoktur. Aşağıdaki örneği düşünün -
<script>
//hoisted to top ; var i = undefined
for (var i = 1;i <= 5;i++){
console.log(i);
}
console.log("after the loop i value is "+i);
</script>
Yukarıdaki kodun çıktısı aşağıdaki gibi olacaktır -
1
2
3
4
5
after the loop i value is 6
Değişken i kullanılarak for döngüsü içinde bildirilir varanahtar kelime. İ değişkenine döngünün dışından erişilebilir. Bununla birlikte, zaman zaman, bir blok içindeki bir değişkenin erişimini kısıtlama ihtiyacı olabilir. Kullanamayızvarbu senaryoda anahtar kelime. ES6,let Bu sınırlamanın üstesinden gelmek için anahtar kelime.
var ve blok düzeyinde güvenlik
Aynısını ilan edersek variable iki kez kullanarak var keywordbir blok içinde, derleyici bir hata atmaz. Ancak bu, çalışma zamanında beklenmeyen mantıksal hatalara neden olabilir.
<script>
var balance = 5000
console.log(typeof balance)
var balance = {message:"hello"}
console.log(typeof balance)
</script>
Yukarıdaki kodun çıktısı aşağıda gösterildiği gibidir -
number
object