زبان جاوااسکریپت پیوسته در حال تکامل است. پیشنهادهایی برای بهتر شدن آن بهطور منظم صورت میگیرد، این پیشنهادها بررسی میشوند و اگر ارزشمند باشند، به لیست https://tc39.github.io/ecma262/ اضافه میشوند و سپس برای مشخصات زبان (specification) پیش میروند.
تیمهای مسئول موتورهای جاوااسکریپت تصمیم میگیرند کدام یک را اول پیادهسازی کنند. ممکن است تصمیم بگیرند پیشنهادهایی که هنوز بهصورت پیشنویس هستند را اول پیادهسازی کنند و پیشنهادهایی که در مرحلهٔ تشخیص هستند را به بعدتر موکول کنند، به دلیل اینکه کمتر جالب هستند و یا فقط سختتر هستند.
پس کاملا طبیعی است که یک موتور فقط بخشی از یک استاندارد را پیادهسازی کند.
یک صفحهی خوب برای این که ببینید در حال حاضر چه چیزهایی پشتیبانی میشود اینجاست https://compat-table.github.io/compat-table/es6/ (خیلی بزرگ است، ما چیزهای زیادی برای مطالعه داریم).
به عنوان توسعهدهنده، ما همیشه دوست داریم از ویژگیها و امکانات جدید استفاده کنیم. هر چه جدیدتر، بهتر!
از طرف دیگر، دوست داریم کدهایمان روی مرورگرهای قدیمیتر که امکانات جدید را نمیفهمند هم کار کنند. اما چطور میشود این کار را انجام داد؟
دو ابزار برای این کار وجود دارد:
- ترنسپایلرها (Transpilers).
- پلیفیلها (Polyfills).
هدف ما در این فصل این است که درک کنیم این دو چگونه کار میکنند و جایگاه آنها در توسعه وب چیست.
ترنسپایلرها
یک ترنسپایلر در واقع قطعهای نرمافزار است که میتواند کد مدرن و جدید را parse کند (“بخواند و بفهمد”) و سپس همان کد را با syntax قدیمی بازنویسی کند بهطوری که خروجی کد یکسان باشد.
برای مثال جاوااسکریپت تا سال ۲۰۲۰ “nullish coalescing عملگر” ??
را نداشت. و اگر کاربری از یک مرورگر منسوخشده استفاده کند، ممکن است کدی مانند height = height ?? 100
را متوجه نشود.
یک ترنسپایلر این کد را آنالیز میکند و height ?? 100
را بهصورت (height !== undefined && height !== null) ? height : 100
بازنویسی میکند.
// قبل از اجرا شدن ترنسپایلر
height = height ?? 100;
// بعد از اجرا شدن ترنسپایلر
height = height !== undefined && height !== null ? height : 100;
کد بازنویسی شده مناسب موتورهای قدیمیتر جاوااسکریپت است.
معمولا توسعهدهنده ترنسپایلر را روی کامپیوتر خودش اجرا میکند و سپس کد transpileشده را روی سرور deploy میکند.
حالا که صحبتش شد، بهتر است بدانید Babel یکی از برجستهترین ترنسپایلرها است.
سیستمهای build پروژه مدرن مثل webpack این امکان را میدهند که بعد از هر بار تغییر کد، ترنسپایلر بهصورت اتوماتیک اجرا شود و برای همین ادغام کردن آن در روند توسعه کار بسیار سادهای است.
پلیفیلها
فیچرها و امکانات جدید یک زبان میتوانند علاوه بر syntax و عملگرهای جدید، تابعهای جدید نیز باشند.
برای مثال Math.trunc(n)
یک تابع است که بخش دهدهی یک عدد را حذف میکند. مانند Math.trunc(1.23)
که 1
را بر میگرداند.
در برخی از موتورهای (خیلی قدیمی) جاوااسکریپت تابع Math.trunc
وجود ندارد و چنین کدی اجرا نمیشود.
از آنجایی که داریم راجعبه تابعهای جدید صحبت میکنیم و بحث تغییر syntax نیست، اینجا چیزی برای transpile وجود ندارد. فقط باید تابع ناموجود را تعریف کنیم.
اسکریپتی که تابعهای جدید آپدیت و یا اضافه میکند، «پلیفیل» نام دارد. در واقع جای خالی را پر میکند و پیادهسازیهای لازم را انجام میدهد.
در این مثال خاص، پلیفیلی که برای Math.trunc
وجود دارد یک اسکریپت است که آن را پیادهسازی کرده است. مانند زیر:
if (!Math.trunc) { // اگر چنین تابعی وجود ندارد
// آن زا پیادهسازی کن
Math.trunc = function (number) {
// Math.ceil و Math.floor جتی در موتورهای قدیمی جاوااسکریپت هم حضور دارند
// و در همین tutorial جلوتر آموزش داده میشوند
return number < 0 ? Math.ceil(number) : Math.floor(number);
};
}
جاوااسکریپت یک زبان بهشدت داینامیک است. اسکریپتها میتوانند هر تابعی را تغییر دهند یا اضافه کنند. حتی تابعهای built-in.
دو کتابخانه جالب پلیفیلها:
- core js که از چیزهای زیادی پشتیبانی میکند و اجازه میدهد فقط فیچرهای مورد نیاز خود را اضافه کنید.
- polyfill.io سرویسی که یک اسکریپت با پلیفیلها ارائه میدهد. بسته به فیچرها و مرورگر کاربر.
خلاصه
در این فصل ما میخواهیم به شما انگیزه بدهیم تا بروید و فیچرهای جدید زبان را یاد بگیرید. حتی اگر هنوز توسط موتورهای جاوااسکریپت بهخوبی پشتیبانی نمیشوند.
فراموش نکنید که از یک ترنسپایلر (اگر از syntax یا عملگرهای مدرن استفاده میکنید) و پلیفیلها (برای اضافه کردن تابعهایی که ممکن است موجود نباشند) استفاده کنید. و با این کار مطمئن خواهید بود که کد شما کار میکند.
برای مثال، بعدها که با جاوااسکریپت آشنایی بیشتری پیدا کنید، میتوانید یک سیستم build کد با webpack و پلاگین babel-loader راهاندازی کنید.
منابع خوبی که نشان میدهند فیچرهای مختلف در چه حالتی از پشتیبانی قرار دارند:
- https://compat-table.github.io/compat-table/es6/ – برای جاوااسکریپت.
- https://caniuse.com/ – برای تابعهای مربوط به مرورگر.
پانوشت گوگل کروم معمولا نسبت به فیچرهای زبان بهروزترین است. اگر دموی یک آموزش کار نکرد، آن را امتحان کنید. البته بیشتر دموهای آموزش با هر مرورگر مدرنی کار میکنند.