- Angular JS Tutorial
- AngularJS Home
- AngularJS Introduction
- AngularJS Expressions
- AngularJS Directives
- AngularJS Modules
- AngularJS Controllers
- AngularJS Scopes
- AngularJS Data Binding
- AngularJS Services
- AngularJS HTTP
- AngularJS Filters
- AngularJS Forms
- AngularJS Validation
- AngularJS DOM Manipulation
- AngularJS Select
- AngularJS Tables
- AngularJS Events
- AngularJS Routing
- AngularJS Includes
- AngularJS Animations
- AngularJS Dependency Injection
- AngularJS API
- AngularJS Deployment
AngularJS Animations
AngularJS provides support for animations through the ngAnimate
module, which allows you to add dynamic effects like fading, sliding, and other transitions when elements enter, leave, or change on the page. Animations in AngularJS help to improve the user experience by making the application feel more interactive and responsive.
Key Concepts of AngularJS Animations
- ngAnimate Module: A built-in AngularJS module used for adding animations to AngularJS applications.
- CSS and JavaScript Animations: AngularJS animations can be done using both CSS transitions and JavaScript, with the framework providing a way to trigger animations based on state changes.
- Animation Hooks: AngularJS provides specific events that trigger animations, such as when an element enters, leaves, or is updated.
How to Use AngularJS Animations
Step 1: Including the ngAnimate Module
To start using animations in AngularJS, you need to include the ngAnimate
module in your AngularJS application.
var app = angular.module('myApp', ['ngAnimate']);
Make sure to also include the necessary CSS files for animation effects:
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/angular-animate/1.8.2/angular-animate.min.css">
Step 2: Animating Element Transitions
You can animate transitions like fading in and out, sliding up or down, etc., by adding the ng-class
or ng-show
and ng-hide
directives.
Example: Fade In/Out Animation
<div ng-app="myApp" ng-controller="myCtrl">
<button ng-click="toggle()">Toggle Visibility</button>
<div ng-show="isVisible" class="fade">This text will fade in and out</div>
</div>
app.controller('myCtrl', function($scope) {
$scope.isVisible = true;
$scope.toggle = function() {
$scope.isVisible = !$scope.isVisible;
};
});
CSS for Animation:
.fade.ng-enter, .fade.ng-leave {
transition: opacity 1s ease;
}
.fade.ng-enter {
opacity: 0;
}
.fade.ng-leave {
opacity: 1;
}
In this example, when the toggle
button is clicked, the element with the class fade
will fade in or fade out depending on the visibility of the isVisible
variable.
Step 3: Using ngAnimate
with ng-show
and ng-hide
The ng-show
and ng-hide
directives automatically trigger AngularJS animations for elements entering or leaving the DOM.
Example: Slide Animation
<div ng-app="myApp" ng-controller="myCtrl">
<button ng-click="toggle()">Toggle Slide</button>
<div ng-show="isVisible" class="slide">This will slide in and out</div>
</div>
.slide.ng-enter, .slide.ng-leave {
transition: transform 1s ease;
}
.slide.ng-enter {
transform: translateY(-100%);
}
.slide.ng-leave {
transform: translateY(100%);
}
- The
slide
class makes the element slide up or down, depending on whether it's entering or leaving the view.
Step 4: Using ng-if
with Animations
The ng-if
directive completely removes elements from the DOM when they are not needed, and re-inserts them when required. This allows you to use animation hooks such as ng-enter
and ng-leave
.
Example: Fade-in with ng-if
<div ng-app="myApp" ng-controller="myCtrl">
<button ng-click="toggle()">Toggle</button>
<div ng-if="isVisible" class="fade">This element is animated with ng-if</div>
</div>
.fade.ng-enter, .fade.ng-leave {
transition: opacity 1s ease;
}
.fade.ng-enter {
opacity: 0;
}
.fade.ng-leave {
opacity: 1;
}
- The element will be completely removed from the DOM when
isVisible
isfalse
, and will fade in when it's re-inserted.
Step 5: Animation with ngRepeat
You can also apply animations when elements are added or removed from lists created with ng-repeat
.
Example: Animate Items in List
<div ng-app="myApp" ng-controller="myCtrl">
<button ng-click="addItem()">Add Item</button>
<ul>
<li ng-repeat="item in items" class="fade">{{ item }}</li>
</ul>
</div>
app.controller('myCtrl', function($scope) {
$scope.items = ['Item 1', 'Item 2'];
$scope.addItem = function() {
$scope.items.push('New Item');
};
});
.fade.ng-enter, .fade.ng-leave {
transition: opacity 1s ease;
}
.fade.ng-enter {
opacity: 0;
}
.fade.ng-leave {
opacity: 1;
}
- In this example, when a new item is added to the list, it will fade in.
Step 6: Using JavaScript to Control Animations
You can control animations programmatically by using AngularJS's $animate
service. This allows you to trigger animations from controllers or services.
Example: Triggering Animation Programmatically
app.controller('myCtrl', function($scope, $animate) {
$scope.triggerAnimation = function(element) {
$animate.addClass(element, 'fade');
};
});
- You can manually add CSS classes to elements, and use
$animate
to trigger custom animations.
Animation States and Callbacks
AngularJS animations provide different states for animations, such as:
ng-enter
for elements entering the DOMng-leave
for elements leaving the DOMng-move
for elements being rearrangedng-animate
for custom animation hooks
You can also attach callbacks to these animations to perform actions when the animation starts or finishes.
Example:
<div ng-repeat="item in items" ng-animate="animationClass">{{ item }}</div>
$scope.animationClass = 'fade';
Summary
AngularJS animations, provided through the ngAnimate
module, offer a way to add smooth, interactive effects to elements as they enter, leave, or change within the DOM. By leveraging CSS transitions and JavaScript callbacks, developers can create dynamic visual experiences. ng-show
, ng-hide
, ng-if
, and ng-repeat
directives work seamlessly with AngularJS animations to manage elements' states. With the help of animation hooks and $animate
service, AngularJS enables fine-grained control over animations, improving both the functionality and aesthetics of web applications.