یک «توسعه‌دهنده فرانت‌اند» به چه مهارت‌هایی نیاز دارد؟
۱۰ فروردین ۱۳۹۹
سارا رشادی‌زاده

آیا تا به‌حال به طراحی سایت مورد علاقه‌ خود دقت کرده‌اید؟ شاید از اینکه چگونه ساخته شده و نحوه عملکرد دکمه‌ها هنگام کلیک کردن، تعجب کرده باشید.

شاید با خودتان فکر کرده‌اید «چقدر پیچیده است!» یا «کاش من هم می‌توانستم چنین کاری انجام دهم.»
تمام این ویژگی‌های قابل مشاهده توسط توسعه‌دهنده فرانت‌اند (front end) ساخته می‌شود.

اگر بخواهیم یک تعریف کوتاه و سریع از نقش توسعه‌دهنده فرانت‌اند داشته باشیم، باید بگوییم که می‌دانیم طراحی وب در واقع نمای سایت را نشان می‌دهد. در این میان توسعه‌دهنده فرانت‌اند کسی است که این طراحی را به واقعیت تبدیل می‌کند و آن را به اجرا در می‌آورد.

توسعه‌دهنده فرانت‌اند چه کسی است؟

توسعه‌دهنده فرانت‌اند کسی است که طراحی وب را از طریق زبان‌های کدنویسی مانند HTML، CSS و Java Script پیاده می‌کند.

هرچند که چندان مرسوم نیست، اما گاهی توسعه‌دهندگان فرانت‌اند را توسعه دهندگان سمت کاربر نیز می‌نامند تا بتوانند آن‌ها را از توسعه‌دهندگان بک‌اند (back end) متمایز کنند.

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

شاید شما هم به شغل توسعه وب علاقه‌مند باشید ولی نمی‌دانید از کجا شروع کنید. ما در این مقاله برخی مهارت‌های کلیدی لازم برای توسعه‌دهندگان فرانت‌اند را مطرح می‌کنیم. دانستن این موارد به شما در شروع مسیر حرفه‌ای توسعه وب کمک زیادی می‌کند.

توسعه‌دهندگان فرانت‌اند چه مهارت‌هایی دارند؟

توسعه‌‌دهندگان فرانت‌اند از سه زبان اصلی کد نویسی برای کد زدن و پیاده‌سازی طرح سایت استفاده می‌کنند:

HTML

CSS

JavaScript

کدی که آن‌ها می‌نویسند، در داخل مرورگر کاربر اجرا می‌شود. (برخلاف توسعه‌دهنده بک‌اند که کد‌هایش بر روی سرور وب اجرا می‌شود.)

به این مثال توجه کنید: توسعه‌دهندگان بک‌اند مهندسانی هستند که سیستم‌های اساسی یک شهر مانند برق، آب و فاضلاب را ایجاد می‌کنند. این در حالی است که توسعه‌دهنده فرانت‌اند دسترسی بیرونی به این سیستم‌ها را برای مردم فراهم می‌کند.

من تلاش کردم تا بفهمم کدام مهارت‌ها در میان فهرست شغلی توسعه‌دهندگان فرانت‌اند بیشترین تقاضا را دارد. در نتیجه این تلاش‌ها، متوجه شدم که برای برنامه‌نویسی سمت فرانت‌اند را ابتدا باید با مهارت‌هایی مانند HTML و CSS شروع کنید. سپس به سراغ مهارت‌های پیچیده‌تری مانند Java Script و Git بروید.

HTML و CSS

این دو اساسی‌ترین بلوک‌های ساختاری کدنویسی در وب هستند. بدون HTML و CSS امکان ندارد بتوانید سایتی ایجاد کنید و تمام چیزی که می‌بینید یک متن ساده و بدون شکل در یک صفحه خالی است. در واقع بدون HTML حتی نمی‌توانید تصاویر را اضافه کنید.

خبر خوب درباره HTML و CSS این است که فقط در عرض چند هفته می‌توانید هر دو را به خوبی یاد بگیرید. بهتر از آن اینکه با دانستن این دو به تنهایی می‌توانید یک سایت ساده بسازید.

Javascript

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

جاوا اسکریپت محبوب‌ترین زبان برنامه‌نویسی در جهان است، بنابراین بد نیست که بدون در نظر گرفتن برنامه‌های شغلی خودتان، یادگیری آن را هم در فهرست یادگیری قرار دهید.

jQuery

جی‌کوئری کتابخانه جاوا اسکریپت است. مجموعه‌ای از پلاگین‌ها (plugins) و اکستنشن‌ها (extensions) که امکان توسعه‌ با جاوا اسکریپت را ساده‌تر و سریع‌تر می‌کند. جی‌کوئری به توسعه‌دهندگان فرانت اند اجازه می‌دهد به‌جای نوشتن کد هرچیزی، از المنت‌های (elements) آماده برای پروژه‌ استفاده کرده و در صورت نیاز آن را شخصی‌سازی کنند. شما می‌توانید از جی‌کوئری برای چیزهایی مانند تایمر شمارش معکوس، فرم جستجوی خودکار و تغییر پیکربندی صفحات به‌صورت خودکار استفاده کنید.

فریم‌ورک‌های جاوا اسکریپت

فریم‌ورک‌های جاوا اسکریپت (شامل آنگولار جی‌اس (AngularJS)، بک‌بون (Backbone)، امبر (Ember) و ری‌اکت جی‌اس (ReactJS)) ساختارهای آماده برای کدهای جاوا اسکریپت به شما ارائه می‌دهند. انواع مختلفی از فریم‌ورک‌های جاوا اسکریپتی برای نیازهای متفاوت وجود دارد، اما این چهار فریم‌ورک، محبوب‌ترین‌ها در میان توسعه‌دهندگان هستند. این فریم‌ورک‌ها شما را یک مرحله جلو می‌اندازند و واقعا سرعت توسعه را افزایش می‌دهند. همچنین می‌توان با استفاده از کتابخانه‌هایی مانند جی‌کوئری، کد نویسی را به حداقل رساند.

فریم‌ورک‌های فرانت‌اند

نقش فریم‌ورک‌های فرانت‌اند (محبوب‌ترین آ‌ن‌ها بوت‌استرپ (Bootstrap) است) برای CSS درست همان نقشی است که فریم‌ورک‌های جاوا اسکریپت برای آن ایفا می‌کنند. آن‌ها نقطه پرش شما برای کد زدن سریع‌تر هستند. از آنجایی که CSS معمولا با المنت‌های مشابهی شروع می‌شود، استفاده از فریم‌ورک می‌تواند به شما کمک زیادی کند.

تجربه کار با پیش‌پردازنده‌های CSS

پیش‌پردازنده‌‌ها گونه‌ای دیگر از المنت‌ها هستند که توسعه‌دهنده فرانت‌اند می‌تواند با استفاده از آن سرعت کدنویسی در CSS را افزایش دهد. یک پیش‌پردازنده CSS یک قابلیت اضافی است که کار بر روی قابلیت‌های CSS را آسان‌تر می‌کند، چرا  که می‌تواند پیش از انتشار کد، آن‌ها را پردازش کند. SASS و LESS دو نمونه از محبوب‌ترین پیش‌پردازنده‌های CSS هستند.

تجربه کار با سرویس‌های RESTful و API

در اصطلاح عام، REST یک معماری سبک است که ارتباطات شبکه‌ای در وب را ساده می‌کند. RESTful و API سرویس‌های مبتنی بر وب به شمار می‌آیند که به این معماری پایبند هستند.

به‌عنوان مثال، شما برنامه‌ای می‌نویسید که اکانت شبکه‌های اجتماعی همه دوستانتان را نمایش دهد تا بتوانید برای آن‌ها درخواست دوستی بفرستید. برای این کار شما باید از RESTful API فیسبوک یا توییتر استفاده کنید تا بتوانید فهرست دوستانتان را بخوانید و داده‌های لازم را برگردانید. روند کلی برای استفاده از خدمات API یکسان است و فقط نوع داده‌های برگشتی متفاوت است.

اگرچه این موضوع کمی پیچیده و فنی به‌نظر می‌رسد، اما مجموعه‌ای ساده از دستورالعمل‌ها و شیوه‌های رایج است. بنابراین یاد می‌گیرید چگونه با یک سرویس وب ارتباط برقرار کنید.

طراحی ریسپانسیو و موبایل

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

به‌عنوان مثال، وقتی وب‌سایتی را با استفاده از مانیتور بزرگ رایانه رومیزی باز می‌کنید، کاربر می‌تواند چندین ستون ببیند و با کمک ماوس و کیبورد از ویژگی‌های مختلف سایت استفاده کند. در گوشی تلفن همراه، همان سایت با استفاده از یک ستون بهینه‌سازی شده برای تعامل لمسی ظاهر می‌شود و دیگر خبری از ستون‌های مختلف نیست.

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

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

توسعه مرورگر

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

سیستم مدیریت محتوا و بستر تجارت الکترونیک

بیشتر وب‌سایت‌ها بر یک سیستم مدیریت محتوا CMS ساخته شده‌اند. محبوب‌ترین CMS در سراسر جهان وردپرس است و تقریبا شصت درصد از وب‌سایت‌های مبتنی بر CMS از آن استفاده می‌‌کنند. (از جمله Skillcrush)

دیگر سیستم‌های مدیریت محتوا محبوب جهان دروپال (Drupal)، جوملا (Joomla) و مگنتو (Magento)  است. البته تسلط به این سیستم‌های مدیریت محتوا به اندازه وردپرس پرطرفدار نیست اما باز هم برای طراحی سایت‌های بسیاری از شرکت‌ها مطلوب هستند.

آزمایش و اشکال‌زدایی (Debugging)

وجود باگ، یک واقعیت در زندگی توسعه‌دهندگان فرانت‌اند است.

آشنایی با مراحل آزمایش و اشکال‌زدایی بسیار مهم است. آزمایش در واقع فرآیند بررسی بلوک‌های تکی از کد منبع (دستورالعمل‌هایی که به وب‌سایت می‌گوید چگونه کار کند) و بررسی چارچوب‌ها با کمک روش‌های خاص است.

یکی از روش‌های متداول آزمایش، بررسی UI است که به آن آزمایش پذیرش یا آزمایش مرورگر نیز گفته می‌شود و طی آن شما اطمینان می‌یابید که کاربر در هنگام کار چه چیزی می‌بیند. شرکت‌های مختلف، راه‌‌حل‌های متفاوتی برای آزمایش و اشکال‌زدایی دارند.

گیت و سیستم‌های کنترل نسخه

Git و سیستم‌های کنترل نسخه به شما این امکان را می‌دهند که در طول کد زدن، تغییرات ایجاد شده را پیگیری کنید. آن‌ها همچنین فرآیند برگشت و اصلاح را آسان‌تر می‌کنند. بنابراین اگر بخواهید افزونه جی‌کوئری سفارشی را اضافه کنید و ناگهان نیمی از کدهای دیگر خراب شود، به‌جای آنکه ناچار به رفع اشکال دستی و بازنویسی باشید، دوباره به نسخه قبلی بازمی‌گردید و این بار یک راه متفاوت را امتحان می‌کنید. دانستن گیت برای هر توسعه‌دهنده‌ای الزامی است و یک مهارت حیاتی به شمار می‌آید.

نکته پایانی: مهارت حل مسئله

اگر یک مهارت برای همه توسعه‌دهندگان فرانت‌اند لازم باشد، آن مهارت حل مسئله است. اینکه بفهمید چگونه باید به بهترین نحو یک طرح را پیاده‌ کنید، اشکال‌زدایی انجام دهید و چگونه آن را اجرا کنید، همگی به مهارت حل مسئله باز می‌گردد. در توسعه همه‌چیز درباره حل مسئله به‌شیوه خلاق است.

ترجمه آزاد: EXACTLY WHAT YOU NEED TO KNOW TO BECOME A FRONT END DEVELOPER IN 2020

تهران، خیابان ابوذر غفاری، کوچه چهاردهم، پلاک ۸، واحد ۲
۲۲۵۰۵۶۶۱ - ۲۲۳۲۴۴۷۲