Curated list with some basic questions when a FrontEnd-WebUI-JavaScript Developer is interviewee.
Test Exam 1: http://plnkr.co/edit/8C1UgO?p=info
var tags = [angular1.3, directives, $http, formValidation, ngMessages, filters];
#Questions
- Why to use AngularJS?
- What are the advantage of AngularJS?
- Does AngularJS has dependency on jQuery?
- What is jQLite/jQuery Lite?
- How to access jQLite?
- What browsers AngularJS support?
- What is the size of AngularJS file?
- What are the AngularJS features?
- When dependent modules of a module are loaded?
- What is Angular's prefixes $ and $$?
- What are Filters in AngularJS?
- What are Directives in AngularJS?
- What is the role of ng-app, ng-init and ng-model directives?
- What are different ways to invoke a directive?
- What is restrict option in directive?
- Can you define multiple restrict options on a directive?
- What is auto bootstrap process in AngularJS?
- What is manual bootstrap process in AngularJS?
- What is scope in AngularJS?
- What is $scope and $rootScope?
- What is scope hierarchy?
- What is the difference between $scope and scope?
- How AngularJS is compiled?
- How AngularJS compilation is different from other JavaScript frameworks?
- How Directives are compiled?
- What are Compile, Pre and Post linking in AngularJS?
- What directives are user to show and hide HTML elements in AngularJS?
- Explain directives ng-if, ng-switch and ng-repeat.
- What are ng-repeat special variables?
- How AngularJS handle data binding?
- What is the difference between $watch, $digest and $apply?
- Explain $watch(), $watchGroup() and $watchCollection() functions on scope.
- Explain AngularJS scope life-cycle.
- Explain digest life-cycle in AngularJS.
- When to use $destroy() function of scope?
- What is the difference between $evalAsync and $timeout?
- What is the difference between $watch and $observe?
- What is the difference between $parse and $eval?
- What is Isolate Scope and why it is required?
- Does AngularJS support MVC?
- What is Model in AngularJS?
- What is ViewModel in AngularJS?
- What is Controller in AngularJS?
- How to share information between controllers in AngularJS?
- What is $emit, $broadcast and $on in AngularJS?
- What is View in AngularJS?
- What are different AngularJS form properties?
- What are different states of a form in AngularJS?
- What is Service in AngularJS?
- What are different ways to create a service in AngularJS?
- What is the difference between Factory, Service and Provider?
- *What is the difference between Kris Kowal's Q and $q?
- What is Restangular?
- What are the advantages of Restangular over $resource and $http?
- What is the difference between $window and
window
in AngularJS? - What is the difference between $document and
window.document
in AngularJS? - What is the difference between $timeout and
window.setTimeout
in AngularJS? - What is the difference between $interval and
window.setInterval
in AngularJS? - What is Routing in AngularJS?
- What is AngularUI router and how it is different from ngRoute?
- What is $injector and $inject?
- What is Dependency Injection in AngularJS?
- What is i18n and L10n?
- What is $locale service?
- How to manage cookies in AngularJS?
- How to detect swite event in mobile browsers/devices in AngularJS?
- How to do animations with AngularJS's helpers?
- What is the directive that support animations?
- How to debug AngularJS app in browser?
- How to securely parse and manipulate your HTML data in AngularJS?
- What is AngularJS 2.0?
- What is TypeScript?
#Answers
There are following reasons to choose AngularJS as a web development framework:
- It is based on MVC pattern which helps you to organize your web apps or web application properly.
- It extends HTML by attaching directives to your HTML markup with new attributes or tags and expressions in order to define very powerful templates.
- It also allows you to create your own directives, making reusable components that fill your needs and abstract your DOM manipulation logic.
- It supports two-way data binding i.e. connects your HTML (views) to your JavaScript objects (models) seamlessly. In this way any change in model will update the view and vice versa without any DOM manipulation or event handling.
- It encapsulates the behavior of your application in controllers which are instantiated with the help of dependency injection.
- It supports services that can be injected into your controllers to use some utility code to fullfil your need. For example, it provides $http service to communicate with REST service.
- It supports dependency injection which helps you to test your angular app code very easily.
- Also, AngularJS is mature community to help you. It has widely support over the internet.
There are following advantages of AngularJS:
- Data Binding - AngularJS provides a powerful data binding mechanism to bind data to HTML elements by using scope.
- Customize & Extensible - AngularJS is customized and extensible as per you requirement. You can create your own custom components like directives, services etc.
- Code Reusability - AngularJS allows you to write code which can be reused. For example custom directive which you can reuse.
- Support – AngularJS is mature community to help you. It has widely support over the internet. Also, AngularJS is supported by Google which gives it an advantage.
- Compatibility - AngularJS is based on JavaScript which makes it easier to integrate with any other JavaScript library and runnable on browsers like IE, Opera, FF, Safari, Chrome etc.
- Testing - AngularJS is designed to be testable so that you can test your AngularJS app components as easy as possible. It has dependency injection at its core, which makes it easy to test.
AngularJS has no dependency on jQuery library. But it can be used with jQuery library.
jQLite is a subset of jQuery that is built directly into AngularJS. jQLite provides you all the useful features of jQuery. In fact it provides you limited features or functions of jQuery.
jQuery lite or the full jQuery library if available, can be accessed via the AngularJS code by using the element() function in AngularJS. Basically, angular.element()
is an alias for the jQuery function.
The latest version of AngularJS 1.3 support Safari, Chrome, Firefox, Opera 15+, IE9+ and mobile browsers (Android, Chrome Mobile, iOS Safari, Opera Mobile). AngularJS 1.3 has dropped support for IE8 but AngularJS 1.2 will continue to support IE8.
The size of the compressed and minified file is < 36KB.
The features of AngularJS are listed below:
- Modules
- Directives
- Templates
- Scope
- Expressions
- Data Binding
- MVC (Model, View & Controller)
- Validations
- Filters
- Services
- Routing
- Dependency Injection
- Testing
A module might have dependencies on other modules. The dependent modules are loaded by angular before the requiring module is loaded. In other words the configuration blocks of the dependent modules execute before the configuration blocks of the requiring module. The same is true for the run blocks. Each module can only be loaded once, even if multiple other modules require it.
To prevent accidental name collisions with your code, Angular prefixes names of public objects with $ and names of private objects with $$. So, do not use the $ or $$ prefix in your code.
Filters are used to format data before displaying it to the user. They can be used in view templates, controllers, services and directives. There are some built-in filters provided by AngularJS like as Currency, Date, Number, OrderBy, Lowercase, Uppercase etc. You can also create your own filters.
Filter Syntax
{{ expression | filter}}
AngularJS directives are a combination of AngularJS template markups (HTML attributes or elements, or CSS classes) and supporting JavaScript code. The JavaScript directive code defines the template data and behaviors of the HTML elements.
AngularJS directives are used to extend the HTML vocabulary i.e. they decorate html elements with new behaviors and help to manipulate html elements attributes in interesting way.
There are some built-in directives provided by AngularJS like as ng-app, ng-controller, ng-repeat, ng-model etc.
The main role of these directives is explained as:
ng-app
- Initialize the angular app.ng-init
- Initialize the angular app data.ng-model
- Bind the html elem
There are four methods to invoke a directive in your angular app which are equivalent.
Method | Syntax |
---|---|
As an attribute | <span my-directive></span> |
As a class | <span class="my-directive: expression;"></span> |
As an element | <my-directive></my-directive> |
As a comment | <!-- directive: my-directive expression --> |
The restrict option in angular directive, is used to specify how a directive will be invoked in your angular app i.e. as an attribute, class, element or comment.
There are four valid options for restrict:
'A' (Attribute)- <span my-directive></span>
'C' (Class)- <span class="my-directive:expression;"></span>
'E' (Element)- <my-directive></my-directive>
'M' (Comment)- <!-- directive: my-directive expression -->
You can also specify multiple restrict options to support more than one methods of directive invocation as an element or an attribute. Make sure all are specified in the restrict keyword as: restrict: 'EA'
.
Angular initializes automatically upon DOMContentLoaded
event or when the angular.js script is downloaded to the browser and the document.readyState
is set to complete
. At this point AngularJS looks for the ng-app
directive which is the root of angular app compilation and tells about AngularJS part within DOM. When the ng-app
directive is found then Angular will:
- Load the module associated with the directive.
- Create the application injector.
- Compile the DOM starting from the ng-app root element. This process is called auto-bootstrapping.
<html>
<body ng-app="myApp">
<div ng-controller="Ctrl"> Hello {{msg}}!
</div>
<script src="lib/angular.js"></script>
<script>
var app = angular.module('myApp', []); app.controller('Ctrl', function ($scope) {
$scope.msg = 'World';
});
</script>
</body>
</html>
You can manually initialized your angular app by using angular.bootstrap() function. This function takes the modules as parameters and should be called within angular.element(document).ready() function. The angular.element(document).ready() function is fired when the DOM is ready for manipulation.
<html>
<body>
<div ng-controller="Ctrl">
Hello {{msg}}! </div>
<script src="lib/angular.js"></script>
<script>
var app = angular.module('myApp', []);
app.controller('Ctrl', function ($scope) {
$scope.msg = 'World';
});
//manual bootstrap process
angular.element(document).ready(function () { angular.bootstrap(document, ['myApp']);
});
</script>
</body>
</html>
Note:
- You should not use the ng-app directive when manually bootstrapping your app.
- You should not mix up the automatic and manual way of bootstrapping your app.
- Define modules, controller, services etc. before manually bootstrapping your app as defined in above example.
Scope is a JavaScript object that refers to the application model. It acts as a context for evaluating angular expressions. Basically, it acts as glue between controller and view.
Scopes are hierarchical in nature and follow the DOM structure of your AngularJS app. AngularJS has two scope objects: $rootScope and $scope.
$scope - A $scope is a JavaScript object which is used for communication between controller and view. Basically, $scope binds a view (DOM element) to the model and functions defined in a controller.
$rootScope - The $rootScope is the top-most scope. An app can have only one $rootScope which will be shared among all the components of an app. Hence it acts like a global variable. All other $scopes are children of the $rootScope. For example, suppose you have two controllers: Ctrl1 and Ctrl2 as given below:
<!doctype html>
<html>
<body ng-app="myApp">
<div ng-controller="Ctrl1" style="border:2px solid blue; padding:5px"> Hello {{msg}}!
<br />
Hello {{name}}! (rootScope) </div>
<br />
<div ng-controller="Ctrl2" style="border:2px solid green; padding:5px">
Hello {{msg}}! <br />
Hey {{myName}}! <br />
Hi {{name}}! (rootScope) </div>
<script src="lib/angular.js"></script>
<script>
var app = angular.module('myApp', []); app.controller('Ctrl1', function ($scope, $rootScope) {
$scope.msg = 'World';
$rootScope.name = 'AngularJS';
});
app.controller('Ctrl2', function ($scope, $rootScope) { $scope.msg = 'Dot Net Tricks';
$scope.myName = $rootScope.name;
});
</script>
</body>
</html>
The $scope object used by views in AngularJS are organized into a hierarchy. There is a root scope, and the $rootScope can has one or more child scopes. Each controller has its own $scope (which is a child of the $rootScope), so whatever variables you create on $scope within controller, these variables are accessible by the view based on this controller.
For example, suppose you have two controllers: ParentController and ChildController as given below:
<html>
<head>
<script src="lib/angular.js"></script>
<script>
var app = angular.module('ScopeChain', []); app.controller("parentController", function ($scope) {
$scope.managerName = 'Shailendra Chauhan';
$scope.$parent.companyName = 'Dot Net Tricks'; //attached to $rootScope
});
app.controller("childController", function ($scope, $controller) {
$scope.teamLeadName = 'Deepak Chauhan';
});
</script>
</head>
<body ng-app="ScopeChain">
<div ng-controller="parentController ">
<table style="border:2px solid #e37112">
<caption>Parent Controller</caption>
<tr>
<td>Manager Name</td>
<td>{{managerName}}</td>
</tr>
<tr>
<td>Company Name</td>
<td>{{companyName}}</td>
</tr>
<tr>
<td>
<table ng-controller="childController" style="border:2px solid #428bca">
<caption>Child Controller</caption>
<tr>
<td>Team Lead Name</td>
<td>{{ teamLeadName }}</td> </tr>
<tr>
<td>Reporting To</td> <td>{{managerName}}</td>
</tr> <tr>
<td>Company Name</td>
<td>{{companyName}}</td> </tr>
</table>
</td>
</tr>
</table>
</div>
</body>
</html>
The module factory methods like controller, directive, factory, filter, service, animation, config and run receive arguments through dependency injection (DI). In case of DI, you inject the scope object with the dollar prefix i.e. $scope. The reason is the injected arguments must match to the names of injectable objects followed by dollar ($) prefix. For example, you can inject the scope and element objects into a controller as given below:
module.controller('MyController', function ($scope, $element) { // injected arguments });
When the methods like directive linker function don’t receive arguments through dependency injection, you just pass the scope object without using dollar prefix i.e. scope. The reason is the passing arguments are received by its caller.
module.directive('myDirective', function () // injected arguments here {
return {
// linker function does not use dependency injection
link: function (scope, el, attrs) {
// the calling function will passes the three arguments to the linker: scope, element and attributes, in the same order
} };
});
In the case of non-dependency injected arguments, you can give the name of injected objects as you wish. The above code can be re-written as:
module.directive("myDirective", function () {
return {
link: function (s, e, a) {
// s == scope
} };
});
// e == element
In short, in case of DI the scope object is received as $scope while in case of non-DI scope object is received as scope or with any name.
..
Thanks to many sites in particular to this guys: