ऑरेलिया - एनिमेशन

इस अध्याय में, आप सीखेंगे कि ऑरेलिया फ्रेमवर्क में सीएसएस एनिमेशन का उपयोग कैसे करें।

चरण 1 - देखें

हमारे विचार में एक तत्व होगा जो एनिमेटेड होगा और ट्रिगर करने के लिए एक बटन होगा animateElement() समारोह।

app.html

<template>
   <div class = "myElement"></div>
   <button click.delegate = "animateElement()">ANIMATE</button>
</template>

चरण 2 - दृश्य-मॉडल

हमारी जावास्क्रिप्ट फ़ाइल के अंदर, हम आयात करेंगे CssAnimatorप्लगइन और यह एक निर्भरता के रूप में इंजेक्षन। animateElementफ़ंक्शन एनीमेशन शुरू करने के लिए एनिमेटर को कॉल करेगा। एनीमेशन अगले चरण में बनाया जाएगा।

import {CssAnimator} from 'aurelia-animator-css';
import {inject} from 'aurelia-framework';

@inject(CssAnimator, Element)
export class App {
   constructor(animator, element) {
      this.animator = animator;
      this.element = element;
   }

   animateElement() {
      var myElement = this.element.querySelector('.myElement');
      this.animator.animate(myElement, 'myAnimation');
   }
}

चरण 3 - शैली

हम अंदर CSS लिखेंगे styles/styles.css फ़ाइल। .myAnimation-add जबकि एक एनीमेशन का प्रारंभिक बिंदु है .myAnimation-remove एनीमेशन पूर्ण होने पर कहा जाता है।

styles.css

.myElement {
   width:100px;
   height: 100px;
   border:1px solid blue;
}

.myAnimation-add {
   -webkit-animation: changeBack 3s;
   animation: changeBack 3s;
}

.myAnimation-remove {
   -webkit-animation: fadeIn 3s;
   animation: fadeIn 3s;
}

@-webkit-keyframes changeBack {
   0% { background-color: #e6efff; }
   25% { background-color: #4d91ff; }
   50% { background-color: #0058e6; }
   75% { background-color: #003180; }
   100% { background-color: #000a1a; }
}

@keyframes changeBack {
   0% { background-color: #000a1a; }
   25% { background-color: #003180; }
   50% { background-color: #0058e6; }
   75% { background-color: #4d91ff; }
   100% { background-color: #e6efff; }
}

एक बार ANIMATEबटन पर क्लिक किया जाता है, पृष्ठभूमि का रंग हल्के नीले रंग से एक गहरे रंग की छाया में बदल जाएगा। जब यह एनीमेशन तीन सेकंड के बाद पूरा हो जाता है, तो तत्व अपनी प्रारंभिक अवस्था में फीका हो जाएगा।