আমি কিছু সময়ের জন্য আমার প্রকল্পগুলিতে একই অ্যানিমেশন প্যাটার্ন ব্যবহার করছি এখন পর্দায় উপাদানগুলিকে অ্যানিমেট করতে। এর সহজতম আকারে, আপনার কাছে শূন্যের অস্বচ্ছতার সাথে স্টাইল করা একটি উপাদান থাকবে, তারপরে একটি সেকেন্ডের CSS ট্রানজিশন সহ একটি অস্বচ্ছতার জন্য স্টাইলিং পরিবর্তন করুন। আমরা ট্রানজিশনের অন্যান্য বৈশিষ্ট্য যোগ করে, সময়কাল পরিবর্তন করে, বিলম্ব যোগ করে বা কাস্টম ইজিং সেট করে এর উপরে তৈরি করতে পারি। একটি পুনঃব্যবহারযোগ্য প্রতিক্রিয়া উপাদান যা আমি যখনই আমার প্রকল্পগুলিতে দ্রুত কিছু অ্যানিমেশন প্রভাব যুক্ত করতে চাই তখনই আমি ড্রপ করেছি। একটি সাধারণ ইউটিলিটি উপাদান, এটি ন্যূনতম প্রচেষ্টার সাথে তরল, নজরকাড়া অ্যানিমেশন তৈরি করতে টেলউইন্ড ক্লাসের সাথে CSS অ্যানিমেশনকে একত্রিত করে। <AnimateIn/> চলুন দেখে নেওয়া যাক কিভাবে এটি ব্যবহার করা হয়। কম্পোনেন্ট ইম্পোর্ট করার পর, টেইলউইন্ড ক্লাস সহ রাজ্য এবং সংজ্ঞায়িত করুন। অ্যানিমেশনকে প্রাণবন্ত দেখতে এর মধ্যে লক্ষ্য উপাদানটি মুড়ে দিন। from to <AnimateIn/>- import AnimateIn from '../animation/AnimateIn'; <AnimateIn from="opacity-0 scale-90" to="opacity-100 scale-100" duration={500} > <YourComponent /> </AnimateIn> এখানে একটি সামান্য জটিল উদাহরণ যা একটি শিরোনাম এবং সাবটাইটেলে অ্যানিমেট করতে আরও বৈশিষ্ট্য ব্যবহার করে। import AnimateIn from '../animation/AnimateIn'; <header> <AnimateIn as="h1" from="opacity-0 translate-y-32" to="opacity-100 translate-y-0" delay={500} duration={300} className="text-4xl" style={{transitionTimingFunction:"cubic-bezier(0.25, 0.4, 0.55, 1.4)"}} > My Big Headline </AnimateIn> <AnimateIn as="h2" from="opacity-0 scale-0" to="opacity-100 scale-100" delay={800} duration={500} className="text-lg" > This is a subtitle below the headline </AnimateIn> </header> শিরোনাম উদাহরণে, একটি ফেইড-ইন এর সাথে মিলিত একটি স্লাইডিং প্রভাব তৈরি করতে ব্যবহৃত হয়। প্রতিটি সম্পত্তি অ্যানিমেশনে কীভাবে অবদান রাখে তা এখানে: <AnimateIn/> সম্পত্তি : সেট করে, আমরা AnimateIn কে অ্যানিমেশনকে উপাদান হিসাবে রেন্ডার করতে বলি। as as="h1" <h1> এবং : বৈশিষ্ট্য শিরোনাম অফ-স্ক্রীন শুরু করে ( , এটিকে 32 ইউনিট নিচে নিয়ে যাওয়া) এবং অদৃশ্য ( )। প্রপার্টি শিরোনামটিকে তার চূড়ান্ত অবস্থানে নিয়ে আসে ( এ ফিরে আসে) এবং এটিকে সম্পূর্ণরূপে দৃশ্যমান করে তোলে ( )। from to from translate-y-32 opacity-0 to translate-y-0 opacity-100 বৈশিষ্ট্য: অ্যানিমেশনটি অবিলম্বে শুরু হতে সেট করা হয়েছে কোনো বিলম্ব ছাড়াই এবং দ্রুত 300ms চলে। duration প্রপার্টি: ফন্ট সাইজ সেট করতে টেইলউইন্ডের ইউটিলিটি ক্লাস প্রযোজ্য, যার ফলে শিরোনামটি বিশেষভাবে আলাদা হয়। className className="text-4xl" বৈশিষ্ট্য: কাস্টম ( ) অ্যানিমেশনে একটি অনন্য সহজতা যোগ করে, এটি একটি বাউন্সের মতো প্রভাব দেয়। style transitionTimingFunction cubic-bezier(0.25, 0.4, 0.55, 1.4) সাবটাইটেলটি শিরোনামকে পরিপূরক করতে অ্যানিমেশনের একটি ভিন্ন সেট ব্যবহার করে, একটি সমন্বিত ভিজ্যুয়াল প্রবাহ তৈরি করে। সম্পত্তি : এখানে, উপাদানটিকে একটি উপাদান হিসাবে উপস্থাপন করে, একটি সাবটাইটেলের জন্য উপযুক্ত। as as="h2" <h2> এবং : সাবটাইটেলটি শূন্য ( ) এবং অদৃশ্য ( ) এ স্কেল করা শুরু হয়, তারপর তার স্বাভাবিক আকার ( ) পর্যন্ত স্কেল করে এবং সম্পূর্ণরূপে দৃশ্যমান হয় ( )। এই স্কেলিং প্রভাব, একটি ফেড-ইন এর সাথে যুক্ত, অ্যানিমেশনে গভীরতা যোগ করে। from to scale-0 opacity-0 scale-100 opacity-100 এবং বৈশিষ্ট্য: সাবটাইটেলটি 800ms বিলম্বের পরেও শুরু হয় যাতে শিরোনামটি সম্পূর্ণরূপে অ্যানিমেটেড হওয়ার পরে এটি শুরু হয়। এই স্তব্ধ পদ্ধতি নিশ্চিত করে যে প্রতিটি উপাদান তার ফোকাসের মুহূর্ত পায়। delay duration প্রপার্টি: সাবটাইটেলের ফন্ট সাইজ সেট করে, এটিকে হেডলাইনের থেকে ছোট করে কিন্তু এখনও তাৎপর্যপূর্ণ করে। className className="text-lg" কী ঘটছে তা আরও ভালভাবে বোঝার জন্য, আসুন এর সোর্স কোডটি দেখি: Github-এ <AnimateIn/> একটি হুক ব্যবহার করে অ্যানিমেশন স্টেটকে এর সাথে প্রারম্ভিক করার জন্য, যেটি এক বা একাধিক Tailwind ইউটিলিটি ক্লাস হওয়া উচিত, কোনো অ্যানিমেশন হওয়ার আগে অ্যানিমেশনের শুরুর বিন্দুর জন্য স্টেজ সেট করে। <AnimateIn/> useState from কম্পোনেন্টে প্রথম হুক হল কম গতির জন্য ব্যবহারকারীর পছন্দকে সম্মান করার জন্য। মিডিয়া ক্যোয়ারী শোনার মাধ্যমে, অ্যানিমেশন আচরণ ব্যবহারকারীর সিস্টেম সেটিংসের উপর ভিত্তি করে। যদি কম গতি পছন্দ করা হয়, তবে অ্যানিমেশনটি সম্পূর্ণভাবে এড়িয়ে যায়, সরাসরি অ্যানিমেশন স্টেটকে সেট করে, একটি অ্যাক্সেসযোগ্য অভিজ্ঞতার জন্য অনুমতি দেয়। useEffect (prefers-reduced-motion: reduce) to দ্বিতীয় হুক হল যেখানে অ্যানিমেশন লজিক থাকে। যদি ব্যবহারকারী হ্রাস গতির জন্য একটি অগ্রাধিকার নির্দেশ না করে থাকে, তবে উপাদানটি একটি টাইমার সেট করে যা নির্দিষ্ট বিলম্বের পরে প্রারম্ভিক মান থেকে চূড়ান্ত মান অ্যানিমেশন অবস্থা পরিবর্তন করে। এই রূপান্তরটি অ্যানিমেশনের চাক্ষুষ প্রভাব তৈরি করে। useEffect from to এই হুকের ক্লিনআপ ফাংশন (রিটার্ন স্টেটমেন্ট) টাইমার সাফ করে, সম্ভাব্য মেমরি ফাঁস প্রতিরোধ করে যেমন অ্যানিমেশন সম্পূর্ণ হওয়ার আগে উপাদানটি আনমাউন্ট করা হয়। ফাংশন কল হল কম্পোনেন্টের রেন্ডারিং মেকানিজম। এটি গতিশীলভাবে prop-এর উপর ভিত্তি করে একটি HTML উপাদান তৈরি করে, যা বিভিন্ন HTML উপাদান জুড়ে উপাদান ব্যবহারের অনুমতি দেয়। ফাংশন ব্যবহার করে তৈরি করা হয়েছে, যা Tailwind-এর ইউটিলিটি ক্লাস, প্রপ হিসাবে পাস করা কাস্টম এবং বর্তমান অ্যানিমেশন অবস্থাকে একত্রিত করে। এই ডায়নামিক ক্লাস অ্যাসাইনমেন্টটি উপাদানটিতে পছন্দসই শৈলী এবং ট্রানজিশন প্রয়োগ করে। React.createElement as shadcn দ্বারা জনপ্রিয় করা cn className className উপরন্তু, একটি বৈশিষ্ট্য আছে যা সরাসরি অ্যানিমেশন কন্টেইনারে স্টাইলিং বৈশিষ্ট্য সেট করতে পাস করা যেতে পারে। প্রপের উপর ভিত্তি করে সেট করা হয়, তবে ব্যবহারকারী যদি কম গতি পছন্দ করে তবে এটি বুদ্ধিমত্তার সাথে এ স্যুইচ করে, কার্যকরভাবে কম্পোনেন্টের কার্যকারিতা বজায় রেখে অ্যানিমেশন অক্ষম করে। style transitionDuration duration 0ms আপনি যদি আপনার নিজের প্রজেক্টে ব্যবহার করতে চান এবং এটি ইতিমধ্যেই ব্যবহার করে, তাহলে আপনার কাছে ইতিমধ্যেই আপনার প্রয়োজনীয় সবকিছু আছে, শুধু এবং আপনার উপাদানগুলিতে যোগ করুন। <AnimateIn/> shadcn AnimateIn.tsx ডাউনলোড করুন অন্যথায়, আপনি চাইবেন পাশাপাশি টেইলউইন্ড ক্লাস মার্জ করার জন্য । Tailwind ইনস্টল করতে mxcn সহায়ক ইউটিলিটি shadcn-এর মতো, <AnimateIn/> হল একটি পুনঃব্যবহারযোগ্য উপাদান যা আপনি কপি করে আপনার অ্যাপে পেস্ট করতে পারেন এবং আপনার প্রয়োজন অনুযায়ী কাস্টমাইজ করতে পারেন। কোড আপনার. এছাড়াও, আমি এ এর সাথে বিভিন্ন অ্যানিমেশন তৈরি করে খেলার জন্য একটি চমৎকার ডেমো পৃষ্ঠা একত্রিত করেছি। animate-in.vercel.app- <AnimateIn/>- এছাড়াও প্রকাশিত এখানে