قبل از شروع این مقاله را به طرح یک سوال آغاز می کنم.
جاوااسکریپت چیست؟
جاوا اسکریپت یک زبان برنامه نویسی پویا و شی محور بوده که برای ایجاد تعامل صفحات مختلف وبسایت باهم بکار میرود. نکته جالب این است که این زبان هم سمت کاربر میباشد و هم سمت سرور.
اما جاوا اسکریپت دقیقا در کدام قسمت های وبسایت حضور دارد؟ در ادامه بخشی از کاربرد های این زبان که همه ما قطعا آن را دیده ایم را با هم مطالعه میکنیم:
_ قابلیت زوم کردن بر روی عکس ها در یک وبسایت
_ اضافه کردن مدیا های صوتی و تصویری به وبسایت
_ انیمیشن هایی که در یک سایت به کار میرود
_ افکت های تصویری و رنگی که با حرکت موس در بخش های مختلف سایت ایجاد میشود
_ اسلایدر ها و کاروسل های تصویر در سایت و…
جاوااسکریپت به صفحات وب جان و رفتار میبخشد
از دیگر کاربرد های زبان برنامه نویسی جاوا اسکریپت میتوان به موارد زیر اشاره کرد:
_ ایجاد برنامه های تحت وب و اپلیکیشن های تلفن همراه
_ طراحی وب سرور و توسعه آن
_ توسعه بازی و …
همانطور که دیدیم زبان جاوا اسکریپت بدلیل انعطاف و قدرت بالا، تقریبا در تمامی قسمت های دنیای دیجیتال ما نقش دارد. اگر نگاهی به آگهی های استخدام و سایت های کاریابی مثل پونیشا، جابینجا و … انداخته باشید، قطعا متوجه خواهید شد که خیلی از شرکت ها به دنبال جذب یک متخصص جاوا اسکریپت حرفه ای هستند و برخی از آن ها حتی قسمت حقوق را برای این پوزیشن شغلی باز گذاشته اند!
از این موارد چه نتیجه ای میتوان گرفت؟
ما در حوزه زبان برنامه نویسی جاوا اسکریپت با یک بازار پر رونق و غیر اشباع طرفیم، چیزی که در ایران کم یاب است!
حالا سوالی که خیلی از دانشجویان از ما می پرسند این است که برای یادگیری جاوا اسکریپت از کجا شروع کنم؟
این سوال باعث شد تا من به فکر تهیه و تنظیم این مقاله بیفتم و برای شما ۹ گامی که برای آموزش زبان برنامه نویسی جاوا اسکریپت باید طی کنید را به طور کامل شرح دهم.
۹ گامی که ما هم در دوره های جامع متخصص جاوا اسکریپت آکادمی آمانج آن را طی میکنیم:
قطعا اولین قدمی که در آموزش هر مطلبی باید طی شود، آشنایی با مقدمات آن به منظور ورود به مطالب اصلی میباشد. در این بخش ما به طور مختصر با تاریخچه و کاربردهای جاوا اسکریپت آشنا شده و بهترین منابع برای مطالعه آخرین مقالات آن را به شما معرفی میکنیم.
شما باید در این مرحله با نحوه کارکرد اینترنت، مرورگرها، مفاهیم IP، DNS ، Domain و پروتکل های HTTP و HTTPS به طور کامل آشنا شوید.
جدا از این موارد که جز اطلاعات عمومی پایه ای هر زبان برنامه نویسی میباشد، آشنایی با هاست های مختلف، دستورات، دیتا بیس ها و محیط های کدنویسی از باید هایی است که در گام اول شما باید آن را به خوبی بیاموزید.
بعد از آشنایی با محیط زبان برنامه نویسی، باید با ساختار کد، متغیر ها، عملگرها، دستورات، حلقه ها، آرایه ها، توابع کتابخانه ای و …به طور کامل آشنا شوید.
این مرحله شاید مهم ترین بخش آموزش هر زبان برنامه نویسی (مخصوصا جاوا اسکریپت) بوده و نیاز به تمرین زیادی دارد. در اصل تسلط به این مفاهیم و مباحث، سنگ بنای پیشرفت و حرفه ای شدن در مراحل بعدی میباشد.
بعد از آموزش این مباحث و تسلط به آن، خطایابی و کدنویسی خوانا از دیگر مباحثی است که باید آن را در زبان برنامه نویسی جاوا اسکریپت بیاموزید.
نکته: همانطور که گفته شد، این قسمت از آموزش ما از اهمیت بالایی برخوردار است. توصیه می شود برای بالا رفتن راندمان کاری خود حتما قبل از گام سوم تسلط خود را در مباحث فوق بهبود ببخشید. برای این مهم برای سطح دانش برنامه نویسی متوسط روزی ۳ الی۴ ساعت تمرین به مدت یک هفته توصیه می شود.
جاوا اسکریپت یکی از زبان های برنامه نویسی تحت وب بوده که وظیفه دارد به سایت ما تعامل و کارایی ببخشد.
بعد از تسلط به مباحث و مفاهیم مرحله قبل نوبت به آن رسیده تا با چند داده و آبجکت بسیار مهم و کاربردی آشنا شویم.
مفهوم polyfill:
polyfill ها در اصل مجموعه کدهایی هستند که یک قابلیت جدید را در مرورگر هایی که از قابلیتهای مورد نظر ما پشتیبانی نمیکنند، ایجاد میکند.
به زبان سادهتر، این کدها به صورت یک مجموعه کتابخانه ای ارائه شده و وظیفه اضافه کردن قابلیت های جدید به مرورگرهای قدیمی یا مرورگرهایی که ویژگی های مورد نظر ما را ندارند را بر عهده دارند.
آشنایی با symbol:
symbol در حقیقت یک متغیر است مثل رشته و یا عدد با این تفاوت که دارای یک identifier یکتا و خاص میباشد.
خب این به چه معناست؟
این بدان معنی است که وقتی ما یک نوع متغیر از نوع symbol داریم، جاوااسکریپت این اطمینان را به ما میدهد که هیچ متغیر دیگری مثل آن نیست. در این بخش آشنایی با نحوه ساخت symbol، کاربردهای آن، بررسیwell-known symbols و آشنایی با shared symbol یک ضرورت اساسی میباشد.
مفهوم garbage collection:
در زبان های سطح بالایی مثل جاوا اسکریپت، عملیات مدیریت حافظه به کمک فرآیند مشهوری به اسم garbage collection انجام میشود.
یعنی این واحد زباله جمع میکند؟ بله! این واحد دقیقا مثل ماشین جمع آوری زباله، در سطح شهر به پیدا کردن حافظه هایی که مورد استفاده نیستند میپردازد.
آشنایی با متد های constructor:
در زبان جاوااسکریپت اگر بخواهیم چند شی بسازیم باید آن ها را تک تک و به صورت دستی طراحی و ایجاد کنیم. قطعا این کار در پروژه های مختلف (چه کوچک و چه بزرگ) بهینه و منطقی نمیباشد.
در این مواقع ما به یک طرح کلی نیاز داریم تا بتوانیم از روی آن چند المان مختلف را بسازیم، برای این کار ما از constructor ها که در واقع نوعی تابع میباشند استفاده میکنیم.
جدا از یادگیری و کار با مفاهیم و توابع فوق، آشنایی با مابقی objectها ، مباحث پیشرفته مربوط به داده و همچنین کار با توابع به صورت حرفه ای، از مجموعه فعالیت هایی است که در مرحله سوم یادگیری زبان جاوا اسکریپت مطرح میشود و شما باید آنها را قبل از ورود به مرحله بعد به طور کامل فرا بگیرید.
آشنایی با مفهوم کلاس
کلاس ها، هسته اصلی زبان های برنامه نویسی شی گرا می باشند. یعنی چه؟
یعنی شما با استفاده از کلاس ها میتوانید اشیاء را با قابلیت توسعه و تغییر فراوان طراحی و ایجاد کنید.
آشنایی با مفهوم وراثت در برنامه نویسی
به زبان ساده وراثت به این مفهوم اشاره دارد که ما کلاسی تعریف کنیم تا کلیهی ویژگیها و یا برخی از ویژگیهای یک کلاس دیگر را داشته باشد.
همچنین از مفهوم وراثت میتوانیم جهت تعریف کلاسی استفاده کنیم که از یکسو تمامی ویژگیهای کلاسی دیگر را داشته و از سوی دیگر برخی ویژگیهای مورد نظر از کلاس اصلی را در آن تغییر دهیم.
در این قسمت نیز، شما باید با انواع مختلف وراثت و کلاس در زبان جاوا اسکریپت آشنا شوید و پس از تسلط به آن وارد مباحث پیشرفته آن شوید.
کاری که ما در کلاس های حضوری و غیر حضوری جاوا اسکریپت آمانج به طور عملی به آن میپردازیم.
در این مرحله شما باید با انواع خطا، پرتاب خطاهای شخصی سازی شده، توسعه کلاس های خطا و … آشنا شده و پس از تسلط به آن با مفاهیم زیر آشنا شوید:
مفهوم Callback:
باید گفت که Callback روشی است که با بهکارگیری آن توسعه دهنده ها میتوانند اجرای یک تابع را ملزم به اتمام اجرای یک تابع دیگر کنند.
این به معنی آن است که تابع و یا دستور مذکور تنها در صورتی اجرا شود که اجرای دستور دیگر به پایان رسیده باشد به همین دلیل به Callback ، فراخوانی مجدد هم گفته می شود.
مفهوم promise:
در جاوااسکریپت Promise نشان دهنده نتیجه یک عملیات ناهمزمان میباشد. به زبان ساده
Promise را میتوان به عنوان یک نگهدارنده تصور کرد. این نگهدارنده در واقع یک object است که میتوانیم callbackها را به آن متصل کنیم.
مفهوم Event loop:
Event loop در اصل وظیفه مانیتور کردن call stack و call back queue ها را برعهده دارد. به زبان ساده این لوپ هر وقت call stack را خالی ببیند از call back ها یک تابع یا کد برداشته و به call stack اضافه میکند و به اجرای آن میپردازد.
نکته: call stack یک ساختار داده ایست که فراخوانی تابع در آن ثبت میشود، بدین شکل که وقتی ما یک تابع را صدا میزنیم، داخل یک stack قرار گرفته و پس از اجرای کامل از آن خارج میشود.
جاوااسکریپت طبق نتایجی که توسط stack overflow منشر شد، در حال حاضر محبوب ترین زبان برنامه نویسی تحت وب میباشد.
Generators:
با استفاده از Generator ها میتوانیم توابعی ایجاد کنیم تا بر اساس تعداد دستورات و فراخوان های انجام شده، خروجیهای متفاوتی را برای ما تولید نماید. در این قسمت شما باید علاوه بر مولدها بر توابع تکرار کننده نیز مسلط شوید.
Modules:
ماژولها از مهم ترین و پراستفاده ترین ویژگیهای دنیای جاوااسکریپت مدرن محسوب میشوند که در حال حاضر در تمام برنامه ها از آن استفاده میشود.
در زبان برنامه نویسی جاوا اسکریپت هر ماژول به صورت یک فایل جداگانه ذخیره شده و می تواند بدون مشکل به یک ماژول دیگر و یا به هسته برنامه اضافه شده و یا از آن جدا بشود.
این ویژگی اغلب در فریم ورک های مختلف بسیار کاربرد دارد و همین موضوع باعث بالا رفتن اهمیت تسلط به آن میشود.
در این بخش شما میبایست با ابزارهای طراحی، UI Kit، ابزارهای انتشار فایل UI، دیزاین سیستم ها، طراحی کامپوننت ها و … آشنا شوید.
به دلیل اهمیت و حجم بالای این مبحث در مقالات بعدی به طور مفصل به معرفی بهترین ابزارهای جاوا اسکریپت برای طراحی و بهینه سازی کدها خواهیم پرداخت.
مزایای جاوا اسکریپت:
قابلیت اضافه کردن بخش های پویا به یک سند ساده HTML
نزدیک بودن جاوا اسکریپت به زبان های برنامه نویسی دیگرامکان استفاده از کتابخانه های آماده این زبان مانند jQueryسادگی در کد نویسی و پیاده سازی آن بدون درگیری با کامپایلرهای پیچیده
در این قسمت شما باید با مفاهیم HTML و CSS به طور کامل آشنا شده و در ادامه به محیط مرورگر وارد شوید.زدر این بخش آشنایی با مفاهیم DOM ، BOM، کار با المان ها و نودهای مرورگر، ویرایش آنها و همچنین کار با فرم ها از اهمیت بالایی برخوردار است.
این مفاهیم بیشتر از جنبه تئوری نیاز به کار عملی و مشارکت در ورکشاپ دارد، نیازی که ما در آکادمی آمانج خلا آن را برطرف ساخته ایم.
میتوان گفت شما تا اینجای کار با تسلط به مباحث گفته شده حدود ۹۰٪ مسیر یادگیری زبان برنامه نویسی جاوا اسکریپت را طی کرده اید و فقط یک گام با ورود به دنیای متخصصان جاوا اسکریپت فاصله دارید.
آشنایی کلی با برنامه نویسی بک اند یا همان سمت سرور، آشنایی با پراکسی ها و مفاهیم API و RESTFUL در قدم اول و در ادامه آشنایی با ابزارهای Post man و Insomnia برای تستAPI ها بخشی از کار شما میباشد.
در گام نهایی شما با یادگیری کار با Local storageها و cookie ها میتوانید ادعا کنید تمام مباحث مربوط به جاوا اسکریپت را تا الان آموزش دیده و صرفا نیاز به تمرین زیاد و دست و پنجه نرم کردن با چالش های مختلف دارید.
زبان برنامه نویسی جاوا اسکریپت یکی از محبوب ترین و پرکاربرد ترین زبان های برنامه نویسی دنیا در سال ۲۰۲۰ میباشد.
به دلیل داغ بودن بازارکار برنامه نویسی و نیاز شرکت ها به کارشناسان جاوااسکریپت من در این مقاله سعی کردم روش اصولی یادگیری جاوااسکریپت را به شما عزیزان آموزش دهم به نحوی که اگر خواستید به صورت خود آموز نیز این زبان برنامه نویسی را یادبگیرید، از راه اصلی خارج نشوید.
این ۹ گام بدون شک میتواند شما را از هر نظر شایسته نام برنامه نویس جاوا اسکریپت کند، اما شما برای متخصص شدن نیاز به مواجه شدن با چالش های مختلف دارید.
کاری که ما در دوره های متخصص جاوا اسکریپت آکادمی آمانج با حضور اساتید درجه یک برنامه نویسی جاوا اسکریپت، آن را برای شما مرتفع خواهیم ساخت.