آموزش استفاده از Grunt برای مدیریت وظایف تکراری - Grunt (جلسه 29) - اضافه کردن Vendor Prefix به کدهای CSS

- visibility ۰ mode_comment

در این مطلب با ادامه آموزش Grunt در خدمتتون هستیم.

grund

در این جلسه قصد داریم در مورد پلاگین grunt-autoprefixer صحبت کنیم و با استفاده از اون Vendor Prefix ها مختلف و متناسب رو به کدهای CSS خودمون اضافه کنیم. این پلاگین از AutoPrefixer استفاده میکنه و از قدرت اون بهره میبره و میتونید از هر ویژگی که در اونجا پشتیبانی میشه در اینجا هم استفاده کنید. این ابزار برای کسب اطلاعات در مورد مرورگرها و ویژگی های مختلف از اطلاعات و Database سایت Can I Use استفاده میکنه و خودش رو بروز میکنه. در ابتدا باید این پلاگین رو در پروژه خودمون نصب کنیم. برای اینکار عبارت زیر رو در cmd قرار میدیم:

بعد از اینکار اینتر میزنیم:grunt install autoprefixer

میبینید که این پلاگین بدون ارور درون پروژه ما نصب شده و حالا اگر package.json رو ببینید، بصورت زیر بروز رسانی شده:grunt install autoprefixer 2

حالا باید این بسته رو درون gruntfile.js لود کنیم:grunt install autoprefixer 3

حالا باید یک وظیفه بنام autoprefixer بسازیم:

دیدید که بعد از task هایی که قبلا ساخته بودیم، وظیفه autoprefixer رو هم ساختیم.

قبل از اینکه تنظیمات درون autoprefixer رو قرار بدیم، یک فایل بنام prefix.css رو درون پوشه css موجود در پوشه development بسازید. درون فایل prefix.css کدهای زیر رو قرار بدین:

دیدید که درون این فایل مورد نظر مقداری کد css قرار داده شده. حالا میخایم کاری کنیم که به این کدها vendor prefix بصورت اتوماتیک اضافه بشه و دستی اونا رو اضافه نکنیم.

حالا میتونیم تنظیمات مورد نظرمون رو درون اون قرار بدیم، برای اینکار بصورت زیر عمل میکنیم:grunt config prefix

میبینید که یک وظیفه بنام prefix ساختیم و درون اون ویژگی files رو قرار دادیم. درون files فایل و مسیر ورودی و خروجی رو مشخص کردیم. حالا برای اینکه اون رو بصورت پیش فرض با زدن grunt اجرا کنیم، autoprefixer رو به آرایه آخر اضافه میکنیم:grunt config prefix 2

حالا اگر grunt autoprefixer رو اجرا کنیم، کارهایی که مشخص کردیم تو یه چشم به هم زدن انجام میشن و فایل مورد نظر ساخته میشه.grunt config prefix 3

میبینید که با موفقیت عملیات مورد نظر انجام شده و حالا اگر به فایل prefix.css ساخته شده در پوشه final نگاه کنید، کدهای زیر وجود دارن:

میبینید که همه prefix ها بصورت زیبا و حرفه ای اضافه شدن و کار شما رو راحت کردن. اگر دقت کنید برای rule آخر که مربوط به a هست یکی از vendor prefix ها که -webkit-border-radius بود، پاک شده است و به دلیل این هست که برای مرورگرهای انتخابی فعلی این مورد نیاز نیس و در مرورگر مورد نظر بهمین صورت پشتیبانی میشه. اساس این ابزار بر پایه browserlist هست. این ابزار اطلاعات مورد نظر خودش رو از سایت Caniuse دریافت میکنه و بعد از اون ما میتونیم با استفاده از Query نوشتن، اطلاعات خاصی رو از اون بیرون بکشیم و استفاده کنیم. مثلا فرض کنید من به browserslist میگم که فقط مرورگرهای ie 6 و 7 رو نیاز دارم. این ابزار این کار رو برام انجام میده و اطلاعات مورد نظر رو از can i use میگیره و کدهای css شما رو متناسب با اون تغییر میده و prefix های مورد نظر رو بهش اضافه میکنه. مثالهایی از Query هایی که میتونین استفاده کنید در اینجا قرار داده شده. اگر این ویژگی رو مشخص نکنید، یک Query پیش فرض در نظر گرفته میشه و اون کوئری > 1%, last 2 versions, Firefox ESR هست. این ابزار یک سایت هم داره که میتونین کوئری های مورد نظر خودتون رو در اون قرار بدین و بعد از اون اینتر بزنید تا مرورگرهای متناسب با اون کوئری به شما نمایش داده بشن. حالا شما میتونین با استفاده از ویژگی browsers این کوئری رو تغییر بدین. بصورت زیر:grunt config prefix 4

حالا اگر مجددا grunt autoprefixer رو اجرا کنید، کدهای خروجی بصورت زیر خواهند بود:

دیدید که با قبل فرق کرده. پس نتیجه میگیریم که ما مرورگرهای مورد نظرمون رو مشخص میکنیم و این ابزار متناسب با اونا، Vendor Prefix های مورد نیاز رو اضافه میکنه و کدهامون رو بهینه نگه میداره. برای بروزرسانی پایگاه داده caniuse در سیستم خودتون عبارت زیر رو در cmd قرار بدین و اینتر بزنید:

برای مطالعه بیشتر در مورد این پلاگین به این لینک مراجعه کنید.

در جلسات بعدی بیشتر در مورد Grunt صحبت میکنیم.

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

موفق باشید

یا علی

comment دیدگاه کاربران

نیاز به لاگین

برای ارسال دیدگاه و یا پرسیدن سوال خود در این قسمت، باید در سایت لاگین شوید.