AngularJS (67 Blogs) Become a Certified Professional
24 Sep 2015
5.5K

AngularJS-Superheroic JavaScript MVW Framework

As web applications are becoming more and more complex in nature, MVC for web application is starting to look much more attractive. If  you are thinking of developing a rich and complex web application then Angular is the way to go. It is much more than any other JavaScript library. It is more of a whole framework.

AngularJS logo - Deep Dive into AngularJS - EdurekaThe above video discusses the superheroic JavaScript MVW framework in AngularJS and covers the following topics:

  • Why should we use AngularJS
  • What is AngularJS
  • MVC & MVW architecture
  • AngularJS features
  • How to build a responsive Single Page Application

Let’s start off with a brief introduction about the founderfs of AngularJS.

AngularJS was originally developed in 2009 by Misko Hevery and Adam Abrons at Brat Tech LLC. Initially, it was named as ‘GetAngular’. AngularJS is an open-source client-side JavaScript framework created by Google. It was designed for web developers and designers, who needed more control over their web Applications. AngularJS accomplishes a lot by embracing HTML, JavaScript and CSS.

What is AngularJS a/c to Misko Hevery?

According to Misko, “A better way to think about angular is not to think about it as framework but as a HTML compiler which allows you to create your OWN DSL in HTML, by attaching your own behavior to any HTML element, attribute or text. And by any, I mean that you can make up your own names (outside those of HTML spec).”

Why AngularJS?

HTML is awesome when it comes to declaring static documents, but staggers when using it for declaring dynamic views in web-applications. AngularJS overcomes this drawback by letting you extend HTML vocabulary for your application. The resulting environment is unbelievably expressive, readable, and quick to develop.

Challenges faced during web development:

There are four key challenges that often present themselves during web development. They are as follows:

  • Responsiveness with different devices
  • Diverse User Preferences
  • Agility to serve new requests with enterprise standards
  • Multiple Skill Sets

These challenges are not inevitable as AngularJS can solve them.

Big brands using AngularJS:

Here’s a list of big companies using AngularJS:

  • YouTube on PS3
  • Netflix
  • Paytm
  • freelancer
  • weather.com

Single Page Application:

As browsers and devices are becoming more and more powerful, there is a huge demand for better and sophisticated experience. AngularJS is capable of complex single-page applications (SPA) that behave like desktop or mobile apps. Single Page Application is a web app in which the bulk of the interactions is handled on the client without the need to reach a server, thereby providing a much more fluid user experience. To create a similar experience without AngularJS proves to be a time-consuming affair.

AngularJS Building Blocks

Model:

A Model is simply a JavaScript object that allows nested models.

View:

The View is based on DOM objects, not on strings. The View is well suited for UI design as it is HTML and is declarative. The view is flexible and allows multiple Views per Controller.

Controller:

Controller is in charge of the construction of the Model and connecting it to the View. The Scope is situated between the Controller and the View. Controllers should contain the logic needed for a View. The Controllers should be thin with rich services.

Scope:

Scope detect the changes in the Model objects and creates an execution context for expressions. There is one root scope for the application with hierarchical children Scopes. It arranges the Model to the View and forward the events to the Controller.

Services:

Services are singletons that perform common tasks for web applications. Services can be used when a common functionality needs to be shared between Controllers. Services can be built through Service API, Factory API, or with $provide API.

Data Binding:

Data Binding  is a two-way binding between the View and the Model. Automatic synchronizing between Views and data Models makes it easy and uncomplicated to use.

Directives:

Directives can be used to transform the DOM or to create new behavior. A Directive lets you extend the HTML vocabulary in a declarative fashion. AngularJS enables you to build your own directives.

Filters:

Filters perform data transformation and can be used to do formatting and filter searching.

Validation:

AngularJS has a couple of built-in validation around HTML5 input variables and Directives. Creating your own validation is as simple as creating a Directive to perform your validation.

Testable:

Testing is a mission-critical factor for enterprise applications. There are several different ways to write and run tests against JavaScript code, a.k.a  AngularJS. Jasmine Tests and Testacular are some of the recommended methods of testing as they are uncomplicated and easy.

Steps to create an AngularJS application:

The following are the steps to create an AngularJS applications:

Step 1 – Include AngularJS

Step 2 – Bootstrap the App

Step 3 – Create the Controller

Step 4 – Create the View

Step 5 – Run the Application

Building Highly Responsive Single Page Application:

Here are the specifications for building a highly Responsive Single Page Application:

Use case: Build a User Management Application

Prerequisite :

  • Text Editor (sublime or notepadd ++)
  • Latest browser (Firefox or Chrome)
  • Installed NodeJS (server)
  • Mongo (To store userinfo)

Project Specifications:

  • Log in to the Application
  • Create a new user
  • View Users List
  • Update an existing user
  • Delete user
  • Signout

Watch the video on top for the demo.

Webinar presentation:

Questions asked during the webinar:

1. What are the advantages of using AngularJS framework?
They are as follows:

  • Two-way Data-binding
  • MVC pattern
  • Static and angular template
  • Addition of custom Directive
  • REST full services
  • Client and Server communication
  • Animations
  • Event Handlers

2. What are the different types of Directive?
The different types of directives are:

  • Attribute Directives
  • Element Directives
  • Comment Directives
  • CSS Class Directives

3. What are the commonly used Directives in AngularJS application?
Some of the commonly used directives are ng-model, ng-App, ng-bind, ng-repeat , ng-show etc.

4. What is the difference between AngularJS and BackboneJS?
AngularJS combines the functionalities of third party libraries and individual functionalities required to develop HTML5 apps while BackboneJS does its jobs individually.

Got a question for us? Please mention them in the comments section and we will get back to you.

Related Posts:

Get Started With AngularJS

What Makes AngularJS Popular

Animation and Testing in AngularJS

ol/u/0/

 

Comments
0 Comments

Join the discussion

Browse Categories

webinar REGISTER FOR FREE WEBINAR
REGISTER NOW
webinar_success Thank you for registering Join Edureka Meetup community for 100+ Free Webinars each month JOIN MEETUP GROUP

Subscribe to our Newsletter, and get personalized recommendations.