![Polymer Logo Polymer Logo](https://3.bp.blogspot.com/-T1egrIKxW1Q/VdhO9WqWb-I/AAAAAAAAYn0/_JzwL1IqN84/s400/polymer-logo.jpeg)
مقدمه
در شرکت داتیس پارس پروژهای داریم که مسئولیت بخش Front-end آن به تیم ما سپرده شده است. قبلتر بخش Front-end با کتابخانه انگولار (AngularJS) توسعه داده شده بود ولی با ارزیابیهای صورت گرفته، تشخیص بر آن شد که به جای AngularJS از کتابخانه Polymer استفاده نماییم. من از حامیان اصلی این تغییر بودم و حالا بعد از چندین هفته مطمئن شدم که گزینه درست را انتخاب نمودهام. این مطلب به معرفی کتابخانه Polymer میپردازد.
با توجه به در دسترس نبودن مستقیم سرویسهایی مانند Youtube و پروتکل HTTPS از داخل ایران و نیز تحریمهای گوگل علیه ایران، ممکن است بخشهایی از ادامه مطلب را به صورت صحیح و یا کامل مشاهده نفرمایید.
با توجه به در دسترس نبودن مستقیم سرویسهایی مانند Youtube و پروتکل HTTPS از داخل ایران و نیز تحریمهای گوگل علیه ایران، ممکن است بخشهایی از ادامه مطلب را به صورت صحیح و یا کامل مشاهده نفرمایید.
بروزرسانی (دلیل استفاده از Polymer به جای AngularJS)
تعدادی از بازدیدکنندگان وبلاگ از طریق ایمیل و یا در بخش نظرات این مطلب، دلیل کنار گذاشتن انگولار و استفاده پلیمر را چندین بار از من پرسیدند و من جداگانه پاسخ هر یک را ارسال نمودم. حال قصد دارم تا مهمترین دلایل این تغییر را برای تمامی بازدیدکنندگان فهرست کنم. ما برای تغییر فریمورک از انگولار به پلیمر پارامترهای مختلفی رو در نظر گرفتیم:
- سادگی پلیمر (از نظر آموزش و توسعه)
- ارائه مدل وب کامپوننتی
- محدودیت زمانی
- سازگاری سادهتر با کتابخانههای مختلف
- در دسترس بودن Element های آماده برای تمامی نیازهای مد نظر ما
- تسریع در توسعه نرمافزار
- در حال حاضر ما از فریم ورک MVC در بخش فرانت اند استفاده نمیکنیم. مدل پلیمر متفاوت از پیادهسازی MVC است.
- انگولار نسخه ۱ از پلیمر پیشتیبانی نمیکند. طبق گفته تیم انگولار، پشتیبانی از وبکامپوننتها از نسخه ۲ به آن اضافه خواهد شد.
معرفی Polymer (پلیمر)
پلیمر کتابخانهی جاوا اسکریپت برای توسعه سایتها و نرمافزارهای تحت وب است. به زبان سادهتر پلیمر مجموعهای از وبکامپوننتها (Web Component) آماده استفاده را در اختیار توسعهدهندگان قرار میدهند. مشابه راهکارهایی که کتابخانههای X-Tag و Bosonic فراهم میکنند.
وبکامپوننت به معنی ایجاد تگهای شخصی و خصوصی سازی شده برای استفاده در وب اپلیکیشنها است.مهمترین هدف پلیمر تغریف زیرساختی برای شکستن کامپوننتها بزرگ به بخشهای کوچکتر است. این کار مزایای از جمله موارد زیر را برای توسعهدهدگان نرمافزارها به همراه دارد:
- کامپوننتها مستقل از یکدیگر خواهند بود. در صورت طراحی صحیح معماری، تغییر در یک کامپوننت، منجر به ایجاد مشکل در سایر کامپوننتها نمیشود.
- از نوشتن کدهای تکراری جلوگیری میشود. شما میتوانید یک کامپوننت مشترک را در چندین کامپوننت دیگر براحتی استفاده نمایید.
- پلیمر (و به صورت کلیتر وب کامپوننت) سرعت توسعه نرمافزار را شتاب میبخشد.
- نگهداری (Maintenance) نرمافزار در بلندمدت کم هزینهتر خواهد بود.
پیشنیازها
پلیمر از استانداردها و ابزارهای مختلفی در کتابخانه خود استفاده کرده است. پیشنهاد میکنم قبل از شروع کار با گوگل پلیمر با عناوین زیر آشنایی پیدا کنید:
نمونه کاربردی Polymer و Web Component
اگر از ابزارهای گوگل و یا سیستمعامل اندروید استفاده کرده باشید، مطمناً چشمتان به کامپوننتهای پلیمر خورده است. به عنوان مثال بخش ظاهری (Front-end) نرمافزارهای Google Translate و اپلیکیشن Youtube بر روی گوشی تلفن همراه با استفاده از کتابخانه پلیمر پیادهسازی شده است.
در زیر با استفاده از کامپوننت paper-button دو دکمه و با استفاده از کامپوننت paper-toast دو نوتیفیکیشن ایجاد کرده ایم. با کلیک کردن بر روی هر دکمه نوتیفیکیشن مربوط به آن را مشاهده خواهد نمود:
از کجا یاد بگیریم؟
بهترین منبع برای یادگیری پلیمر وبسایت پلیمر به آدرس polymer-project.org است. این وبسایت و بخش عناصر (elements.polymer-project.org) به سرعت در حال تغییر و توسعه هستند. برای شروع پیشنهاد میکنم ویدئو معرفی Polymer 1.0 در همایش Google I/O 2015 را در ادامه مشاهده فرمایید:
منابع و اطلاعات بیشتر
پینوشت: فرصتهای شغلی
برنامهنویس جاوا اسکریپت
در صورتیکه به پلیمر علاقمند هستید و تجربه کافی در زمینه JavaScript و کتابخانههای آن مانند AngularJS، BackBoneJS و... دارید، خوشحال میشویم که عضو جدید تیم ما باشید.
طراح رابط کاربری (UX/UI)
اگر تجربه لازم در طراحی رابط کاربری و آشنایی کافی با HTML و CSS دارید، خوشحال میشویم که عضو جدید تیم ما باشید.
برنامهنویس جاوا
در صورتیکه علاقمند به کار در بخش Back-end پروژه هستید، شرکت ما در حال جذب نیرو برای این بخش نیز است. آشنایی کافی با جاوا و داشتن تجربه کار تیمی مهمترین معیارهای جذب نیرو در شرکت ما است.
روزمه خود را ارسال کنید!
لطفا رزومه خود را به آدرس [email protected] یا [email protected] ارسال نمایید. از ارسال رزومه برای کار پارهوقت و یا پروژهای پرهیز کنید. در حال حاضر فقط نیروی تماموقت جذب میکنیم.