Statement ها و موتور های جاوا اسکریپت

4 2,460

با سلام و عرض ادب، در قسمت قبل با چگونگی بارگذاری کدهای جاوا اسکریپت در فایل HTML آشنا شدیم و چندین راه مختلف برای آن بیان کردیم. در این قسمت سراغ Statement ها (در فارسی به معنی اعلان یا بیان) خواهیم رفت.

Statement در جاوا اسکریپت چیست؟

حتما میدانید که یک برنامه ی کامپیوتری لیستی از “دستورات” است که باید توسط کامپیوتر اجرا شوند. حالا در زبان های برنامه نویسی، این دستورات statement نام دارند و بر همین اساس یک برنامه ی جاوا اسکریپت لیستی از statement ها است (یادتان باشد که statement در واقع همان چیزی است که در زبان عامیانه به آن کد میگوییم! 

statement های جاوا اسکریپت به معنی کدهای جاوا اسکریپت است، اما برای اینکه ذهن شما این مورد را از یاد نبرد در طول این جلسه فقط از کلمه ی statement استفاده می کنیم و از جلسات بعد از همان کلمه ی خودمانیِ کد!).

برنامه های جاوا اسکریپت در HTML توسط مرورگر اجرا می شوند و تمام مروگر ها یک موتور جاوا اسکریپت دارند که با آن statement ها را اجرا می کنند.

آیا از موتور جاوا اسکریپت چیزی می دانید؟

موتور های جاوا اسکریپت در واقع ماشین های مجازی هستند. حتما با خودتان می گویید این چه تعریفی بود که فرقی با نبودنش نداشت!

اگر بخواهم به زبان ساده تر بگویم ماشین های مجازی شبیه ساز های نرم افزاری هستند که روی یک سیستم اجرا می شوند.

به طور مثال اگر کاربر سیستم مک باشید (کامپیوتر های اپل) احتمالا با ماشین مجازی Parallels آشنا هستید. این ماشین مجازی به شما اجازه میدهد نرم افزار های ویندوز را روی مک اجرا کنید. اگر کاربر لینوکس هستید احتمالا با ماشین مجازی Wine آشنا هستید که اجازه می دهد نرم افزار های ویندوز را روی لینوکس اجرا کنید. اگر بخواهم باز هم دقیق تر توضیح بدهم، میگویم Wine یک ماشین مجازی پردازشی است.

ماشین های مجازی پردازشی مثل Wine به شما مانند ماشین های مجازی سیستمی (مثل Parallels) هستند اما فرقشان در اینجاست که Parallels یک سیستم کامل (محیط کامل ویندوز) را در اختیار شما قرار می دهد اما Wine فقط به شما اجازه میدهد نرم افزار های ویندوز را روی  لینوکس اجرا کنید و دیگر محیط ویندوز را در اختیار شما نمیگذارد.

حالا برمیگردیم به جاوا اسکریپت! موتور های جاوا اسکریپت در واقع ماشین های مجازی پردازشی هستند که به طور خاص طراحی شده اند تا بتوانند کدهای جاوا اسکریپت را اجرا کنند.

بر همین اساس می توان گفت هر موتور جاوا اسکریپت نوعی از استاندارد ECMAScript را پیاده سازی میکند و بر اساس آن کدها را اجرا میکند. در جلسات قبل گفتیم که ECMAScript یک استاندارد کد نویسی است که جاوا اسکریپت از آن پیروی میکند.

در جدول زیر نام موتور های جاوا اسکریپتی که مرورگر های مختلف و یا سیستم های مختلف از آن ها استفاده می کنند را برایتان آورده ام:

موتور جاوا اسکریپت مرورگر و یا Runtime
Spidermonke Mozilla
V8 Chrome
JavaScriptCore Safari
Chakra IE and Edge
JavaScriptCore PhantomJS
Rhino HTMLUnit
V8 TrifleJS
V8 Node.js
V8 Io.js

حالا اینهمه گفتیم که چه؟ چرا باید این چیز ها برایمان اهمیت داشته باشد؟

هدف موتور های جاوا اسکریپت تجزیه و اجرای کد در کمترین زمان ممکن و به بهینه ترین صورت ممکن است. شما به عنوان یک توسعه دهنده ی وب باید حداقل با مفاهیم این چنینی آشنا باشید تا بتوانید موتور های جاوا اسکریپت را مقایسه کنید. تست زیر روی موتور های مختلف جاوا اسکریپت انجام شده است و میبینید که عملکرد موتور های مختلف متفاوت است!

عملکرد موتورهای جاوا اسکریپت

یکی از وب سایت های مشهوری که در این زمینه تست های مختلفی انجام میدهد وب سایت arewefastyet.com است. شما می توانید به این وبسایت مراجعه کنید و عملکرد مرورگر های مختلف را در ویندوز های مختلف و در زمینه های مختلف مشاهده کنید. نگران نباشید!

نیازی به حفظ کردن و یا حتی یادگیری این چیز ها نیست اما آشنایی حداقلی با آنها حتی در همین حد مهم است.

برگردیم به statement ها! اول یک مثال از statement ها ببینید:

چهار statement مختلف را میبینید!

گفتیم statement ها دستوراتی هستند که اجرا می شوند بنابراین تک تک این خط ها یک statement هستند. مثلا خط اول میگوید متغیر های x و y و z را تعریف کن. طبیعتا این یک دستور است. خط دوم می گوید متغیر x را مساوی 5 قرار بده. این هم یک دستور است الی آخر … .

statement در جاوا اسکریپت شامل موارد زیر هستند:

  • values (مقادیر)
  • Operator (اپراتور ها)
  • Expressions (عبارات)
  • Keywords (کلمات کلیدی)
  • Comments (کامنت ها)

برای مثال statement زیر یک تگ </p> با آیدی demo را می گیرد و مقدار آن را برابر “Hello From Roxo” قرار میدهد.

این کد را در قالب یک مثال کامل ببینید:
میتوانید این کد را از ادیتور آنلاین در این لینک اجرا کنید.

همچنین باید بدانید که statement ها در جاوا اسکریپت با نقطه‌ویرگول (Semicolons) از هم جدا می شوند بنابراین شما موظف هستید که در پایان هر statement یک نقطه‌ویرگول قرار دهید. به مثال زیر نگاه کنید:

اگر نقطه‌ویرگول در هر کدام از statement های بالا حذف شود کل کد دچار مشکل شده و اجرا نمی شود!

یکی از شایع ترین مشکلات برنامه نویسان تازه کار در جاوا اسکریپت رعایت کردن همین نقطه‌ویرگول هاست. تصور کنید در یک اسکریپت 900 خطی یک نقطه ویرگول کم باشد! می شود مانند پیدا کردن سوزن در انبار کاه!

از همین جهت به شما پیشنهاد می کنیم از ویرایشگر های محبوب جاوا اسکریپت برای کد نویسی استفاده کنید. چند نمونه از این ویرایشگر ها PHPStorm و Brackets و Atom و Visual Studio Code هستند.

پیشرفته ترین آنها PHPStorm است که هم سنگین بوده و هم پولی (کرک نرم افزار موجود است).

تصویر زیر یک راهنمای مختصر برای شماست تا با علائم نگارشی در برنامه نویسی و اسم های انگلیسی آن ها آشنایی پیدا کنید.

علائم نگارشی برنامه نویسی
علائم نگارشی برنامه نویسی

تا اینجای کار قسمت اول statement ها را به پایان رساندیم. در قسمت بعدی مطالب بیشتری در رابطه با Statement ها ارائه خواهیم کرد.

تا قسمت بعدی، یا حق.

ترتیبی که روکسو برای یادگیری مطالب سری آموزش جاوا اسکریپت | Javascript به شما توصیه می‌کند:
4 نظر
  1. همایون

    عالی خدایی بهترین سایتی که اموزش برنامه نویسی میده
    فقط آموزش php هم میشه بزاری داداش؟؟
    واقعا خوب آموزش میدی و واقعا ممنون که انقدر کامل و خوب توضیح میدی
    گفتم اگر نگم کم لطفی کردم

  2. محسن آستانه

    دمت گرم امیر جان
    داداش برای انگلیسی که به درد برنامه نویسی بخوره (منظورم همون زبان تخصصی مخصوص برنامه نویسی) منبع یا منابع خوبی سراغ داری؟ چون کتاب های ترمیکی مثل امریکن انگلیش فایل و … فکر نکنم به درد این کار بخوره. اگه منبع خاصی می شناسی ممنون میشم معرفی بکنی. یا این که بهتر هست خودت یه بخش جدید تو سایت درست بکنی و مفاهیم مخصوص این قسمت رو یکی یکی بیان بکنی! صد البته که با این مقاله های ارزشمندی هم که می خونیم دانش انگلیسیمون هم بالا میره.

    1. امیر زوارمی

      سلام دوست عزیز،
      حتما راجع به پیشنهاد خوبت فکر می کنم!

  3. سید محمد

    مرسی ، در پاراگراف یکی مونده به آخر اشتباه تایپی وجود داره!
    اشتباهات رایج برنامه نویسان جاوا اسکریپت ، رعایت کردن نقطه ویرگول است ( رعایت نکردن نقطه ویرگول است . )
    سپاس از مطالبتون ❤

ارسال نظر

توجه:‌ آدرس ایمیل شما منتشر نخواهد شد.

mezitli escort
mezitli escort