<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های میلاد رستمی</title>
        <link>https://virgool.io/feed/@MiladRostami01</link>
        <description>عاشق برنامه نویسی</description>
        <language>fa</language>
        <pubDate>2026-06-15 16:56:41</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/88364/avatar/q8LRYO.jpeg?height=120&amp;width=120</url>
            <title>میلاد رستمی</title>
            <link>https://virgool.io/@MiladRostami01</link>
        </image>

                    <item>
                <title>بررسی scope در JavaScript</title>
                <link>https://virgool.io/@MiladRostami01/%D8%A8%D8%B1%D8%B1%D8%B3%DB%8C-scope-%D8%AF%D8%B1-javascript-ep3vqvdg2h3m</link>
                <description>از جمله مباحث گیج کننده ای که هنگام مصاحبه ها با اون مواجه میشیم میتونه scope ها باشه.درک بهتر scope ها میتون از باگ های خاموش جلوگیری کنه . پس بدونه فوت وقت بریم سر اصل داستانقبل از هرچیز خوبه بدونیم که scope چیه و به چه درد میخوره ؟ scope خیلی ساده بخوام بگم، یک محدوده از برنامه هست که داخل اون متغییر قابل دسترسهنکته: scope در کل قراره راجب ( متغییر ها ، فانکشن ها ، آبجکت ها )  به ما بگه که اینجا میتونی از فلان ( متغییر فانکشن یا آبجکت ) استفاده کنی یا نه !سه نوع scopeداریم :1. Global scope2. Function scope ( Local scope )3. Block scopeگلوبال اسکوپ Global scopeبه بیرونی ترین لایه برنامه ( خارج از function scope و block scope ) میگن global scope// Global Scope
const name = &amp;quotmilad&amp;quot

function func() {
  alert&#40;name&#41;; // milad
}

func();متغییر های گلوبال در سرتاسر برنامه قابل دسترسی و استفاده هستند
const name = &amp;quotmilad&amp;quot
//name is available

function func() {
  //name is available
}
//name is availableمتغییرهای Const, Let, Var در global scope  یک جور رفتار میکنند. یعنی  از لحاظ در دسترس بودن متغیر ما  چه var باشه چه let  چه const همه یک رفتار رو از خودشون نشون میدن ( حالا جلوتر متوجه میشیم. قول میدم :)  فانکشن اسکوپ : Function scope یا Local scopeهمونطور که از اسمش پیداس به اسکوپ فانکشن ها گفته میشهfunction func(){
  //Local scope
}متغییر های لوکال فقط و فقط داخل فانکشن دردسترس هستندداخل اسکوپ فرزند میتونیم به متغییرهای اسکوپ پدر دسترسی داشته باشیم ولی برعکسش این قضیه با ارور مواجع میشهvar x = 1
// y is not available :   error 

function func() {
  // x is available
 var y = 2
}
// y is not available :   error متغییرهای Const, Let, Var در function scope  یک جور رفتار میکنند. یعنی  از لحاظ در دسترس بودن متغیر ما  چه var باشه چه let  چه const همه یک رفتار رو از خودشون نشون میدن ( جلوتر متوجه میشیم )  بلاک اسکوپ Block scopeبلاک به محدوده داخل {...} گفته میشه مثل: {...}()if{...}, while(){...}, forخوب قول داده بودم که جلوتر متوجه میشم ! الان وقتشه تو دو مورد قبل گفتیم که متغییرهای Const, Let, Var یک جور رفتار میکنند  ولی اینجا اینطور نیست به این عکس نگاه کنید :|یک بلاک اسکوپ نتیجه اشاینجا تو خط چهارم به متغییر secret ( که var هست )  دسترسی داریم و حتی مقدار اون رو میتونیم تغییر بدیم !!!!!  که این موضوع خودش میتونه منجر به باگ های زیادی بشه . ( این اون تفاوته است ، خارج از بلاک اسکوپ میتونیم به متغییر var دسترسی داشته باشیم، برخلاف موارد قبل )خوشبختانه در ES6، جاوااسکریپت جهت جلوگیری از این اتفاق Const , Let رو آورد که جلوی این داستان رو بگیره ( دمش گرم ) اینجا var بیرون از scope هم قابل کنترله برخلاف حالت function scope اگه این چیزای که گفتم رو بخوام به صورت نکات کنکوری دربیارم اینطوری میشه :نکته: داخل block scope  متغییر های const , let , var دردسترس هستندنکته: بیرون از block scope متغییر های const , let  در دسترس نیستند نکته: بیرون از block scope متغییر های var در دسترس هستند جهت واضح شدن نکته بالا کد زیر رو ببینیم : if( true ) {
// our block scope

  const x = 1;
  let y = 2;
  var z = 3;

  // x, y, z are available

}

// x, y are not available
// z is available !!!نکته : در block scope ها، متغییر های var میتونند  هم به متغییر های scope پدر و هم  scope فرزند دسترسی داشته باشند ولی const , let  فقط میتونند به متغییر های scope پدر دسترسی داشته باشند جهت وضوح کار کد زیر رو ببینید: while(true ) {
// our block scope
const a =  1;
let b = 2 ;
var c = 3;

// x, y are not available    // z is available !!!

if( true ) {  
   // our block scope
   const x =  1;   
   let y =  2;   
   var z =  3;    

   // x, y, z are available    // a, b, c are available  too
  }  
}مفهومی به اسم  Automatically globalاینم بدونیم بد نیست !اگر به متغییری که تعریف نشده ( const, let, var نداره) رو مقدار دهی کنیماون متغییر به صورت global درنظرگرفته میشهنکته : متغییری که تعریف نشده ( const, let, var نداره) حتی اگر داخل function هم باشه باز به صورت global درنظر گرفته میشه . مثل کد زیر :myFunction();

// code here can use carName

function myFunction() {
  carName = &amp;quotPride !&amp;quot
}
نکته : زمانی که در حالت strict mode باشیم متغییرهایی که تعریف نشده اند ( const, let, var نداره) به صورت global درنظر گرفته نمیشهو نکته اخرهم اینکه بدون حساب و کتاب، متغیر ها Global ایجاد نکنید چرا که این متغیر ها و توابع میتونند متغیر ها یا توابعِ شیء window را overwrite کنند. تنها زمانی از متغیر های سراسری استفاده کنید که کاملا نسبت به شرایط آگاهی داشته باشیدعرضی نمونده مراقب خودتون باشیدآها راستی اگه که نظری داشتید خیلی خوشحال میشم تو کامنت ها بهم بگید ? </description>
                <category>میلاد رستمی</category>
                <author>میلاد رستمی</author>
                <pubDate>Mon, 31 Jan 2022 16:05:47 +0330</pubDate>
            </item>
            </channel>
</rss>