تبلیغات

کتابخانه Velocity.js جاوا اسکریپت (ولوسیتی) – ساخت انیمیشن

کتابخانه Velocity.js جاوا اسکریپت (ولوسیتی)
Accelerated JavaScript animation
ساخت سریع و آسان انیمیشن در جاوا اسکریپت


Velocity، یک موتور انیمیشن همانند API جی‌کوئری ‘$.animate()‘ می‌باشد که هم با جی‌کوئری و هم بدون جی‌کوئری کار می‌کند! این کتابخانه، به‌طور باورنکردنی سریع بوده و شامل ویژگی‌های color animation، transforms، حلقه‌ها، easings، پشتیبانی از SVG  و اسکرول نیز می‌باشد. همچنین این لایبری، بهترین ترکیب transitions جی‌کوئری و CSS است.

شروع به کار

فایل را از انتهای مطلب دانلود کرده و در صفحه‌ی خود وارد کنید. یا می‌توانید از مخزن (CDN) های زیر استفاده کنید:

سپس تمامی دستورات $.animate() را با $.velocity() جایگزین نمایید. حالا شما بلافاصله افزایش عملکرد (پرفورمنس) را در تمامی دستگاه‌ها و مرورگرها (به ویژه موبایل) مشاهده خواهید کرد.

سازگاری

Velocity در همه‌جا کار می‌کند. حتی در نسخه‌های قبل از IE8 و اندروید 2.3 به پایین! در واقع این کتابخانه، از دستور $.queue() تقلید کرده و سپس به طور یکپارچه، با دستورات $.animate() و $.fade() و $.delay() جی‌کوئری همکاری می‌کند. و همچنین از آنجایی که سینتکس Velocity همانند دستور $.animate() می‌باشد، کد شما نیاز به تغییر نخواهد داشت!

استفاده از velocity با جی‌کوئری

همنطور که گفته شد، Velocity.js به طور یکپارچه‌ای با جی‌کوئری کار می‌کند. توابع $.animate() و $.delay() و $.fade() جی‌کوئری را نیز می‌توان در کنار Velocity استفاده کرد. هیچ تنزل (کاهش) عملکردی (پرفورمنسی) در استفاده از Velocity با جی‌کوئری وجود ندارد.

استفاده از velocity بدون جی‌کوئری

Velocity.js همچنین زمانی که کتابخانه‌ی jQuery در صفحه‌ی شما لود نشده باشد هم کار می‌کند. اما استفاده از Velocity بدون جی‌کوئری، پشتیبانی آن را برای مرورگر IE8 به پایین از دست می‌دهد (البته مهم هم نیست)  و فقط برای IE9 به بالا پشتیبانی خواهد شد.

اگر کتابخانه‌ی Zepto در صفحه‌ی شما استفاده شده باشد، Velocity همانند جی‌کوئری با Zepto نیز کار می‌کند.

وقتی جی‌کوئری و زپتو در صفحه حضور نداشته باشند، Velocity خود را به آبجکت window متصل می‌کند. به این ترتیب، انیمیشن‌ها با توابع Velocity راه‌اندازی می‌شوند؛ که در نتیجه، المنت‌های خام (خالص) DOM، به عنوان اولین پارامتر به Velocity پاس داده خواهند شد:

این کد یالا، نحوه‌ی استفاده از Velocity بدون حضور جی‌کوئری است. اما اگر جی‌کوئری وجود داشته باشد، همین کد به صورت زیر خواهد بود:

در مورد Zepto نیز به همین صورت بوده و از همین $ استفاده می‌شود.

پلاگین‌های Velocity

Velocity در حال حاظر شامل چند پلاگین اصلی می‌باشد: (این پلاگین‌ها بایستی بعد از Velocity در صحفه بارگزاری شوند)

UI Pack

این پلاگین در فایل دانلودی موجود در انتهای مطلب نیز قرار دارد. و همچنین از طریق دو مخزن CDN زیر نیز قابل دسترسی می‌باشد:

UI Pack، در واقع گردش کار انیمیشن‌های شما را بهبود می‌بخشد. این پلاگین، دو تابع $.Velocity.RegisterEffect() و $.Velocity.RunSequence() را برای Velocity فراهم می‌کند. و همچنین برای کاربران AngularJS نیز در این‌لینک در دسترس می‌باشد.

مثال: (لینک در codepen)

VMD

Velocity Motion Designer یا VMD نیز به شما کمک می‌کند تا انیمیشن‌ها را به صورت رئال تایم (real-time) ایجاد کنید! این پلاگین به صورت bookmarklet است؛ بدین معنا که داخل بوکمارک مرورگر وب ذخیره شده و به کاربر اجازه می‌دهد تا به نحوی، با صفحه‌ی وب بارگزاری شده تعامل داشته و به تولید انیمیشن بپردازد. با استفاده از این پلاگین، زمانی که شما انیمیشن خود را ایجاد کنید، می‌توانید عملکرد خود را به کد Velocity تبدیل نمایید. و در واقع VMD باعث صرفه‌جویی زیادی در زمان شما خواهد شد و به توسعه‌ی سریع شما کمک می‌کند.

خروجی کدهای تولید شده با VMD را می‌توانید در Console بخش Inspector مرورگر خود مشاهده کنید.

جهت فعال کردن VMD در صفحه:

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

روش دوم: می‌توانید کد زیر را در فایل خود قرار دهید تا VMD بارگزاری شود.

روش سوم: کد زیر را کپی کرده و در Console بنویسید:

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

– برای دیدن ویدیوی معرفی می‌توانید «این لینک یوتیوب» را مشاهده کنید.

صفحات رسمی Velocity.js

تبلیغات
0
کانال تلگرام فول کده
تبلیغات

درباره نویسنده

هادی اکبرزاده

[ مدیر فول کده ]

علاقه‌مند به اشتراک گذاری اطلاعات در هر زمینه‌ای / برنامه‌نویس و دانشجوی ارشد رشته شبیه‌ساز هوشمند / همچنین در حال نوشتن یه رمان فانتزی (اگه خدا بخواد و تموم شه 😂)

پاسخ دهید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

نظرات ثبت شده بدون دیدگاه