Data-binding is an automatic way of updating the view whenever the model changes, as
well as updating the model whenever the view changes. This is awesome because it
eliminates DOM manipulation from the list of things you have to worry about.
Controllers are the behavior behind the DOM elements. AngularJS lets you express the
behavior in a clean readable form without the usual boilerplate of updating the DOM,
registering callbacks or watching model changes.
Unlike other frameworks, there is no need to inherit from proprietary types in order to wrap the
test, maintain, reuse, and again free from boilerplate.
A deep link reflects where the user is in the app, this is useful so users can bookmark
and email links to locations within apps. Round trip apps get this automatically, but
AJAX apps by their nature do not. AngularJS combines the benefits of deep link with
desktop app-like behavior.
Client-side form validation is an important part of great user experience.
AngularJS lets you declare the validation rules of the form without having to write
AngularJS provides built-in services on top of XHR as well as various other backends
using third party libraries. Promises further simplify your code
by handling asynchronous return of data. In this example, we use the AngularFire
library to wire up a Firebase backend to a simple Angular app.
Directives is a unique and powerful feature available only in Angular. Directives let
you invent new HTML syntax, specific to your application.
We use directives to create reusable components. A component allows you to hide complex
DOM structure, CSS, and behavior. This lets you focus either on what the application
does or how the application looks separately.
An important part of serious apps is localization. Angular's locale aware filters and
stemming directives give you building blocks to make your application available in all
AngularJS works great with other technologies. Add as much or as little of AngularJS to
an existing page as you like. Many other frameworks require full commitment. This page
has multiple AngularJS applications embedded in it. Because AngularJS has no global
state multiple apps can run on a single page without the use of
encourage you to view-source and look around.
The dependency injection in AngularJS allows you to declaratively describe how your
application is wired. This means that your application needs no
method which is usually an unmaintainable mess. Dependency injection is also a core to
AngularJS. This means that any component which does not fit your needs can easily be
AngularJS was designed from ground up to be testable. It encourages behavior-view
separation, comes pre-bundled with mocks, and takes full advantage of dependency
injection. It also comes with end-to-end scenario runner which eliminates test flakiness
by understanding the inner workings of AngularJS.