prep for interview Flashcards
root scope
every ang js app has a root scope
all the child scopes inherit fom the root scope
Each view has its own $scope (which is a child of the root scope), so whatever variables one view controller sets on its $scope variable, those variables are invisible to other controllers.
$inject
can be used to inject dependencies
module config block vs module run block
data:image/s3,"s3://crabby-images/09fe9/09fe921a2e77ee54d4336637b5e2f41263ab8ca3" alt=""
ngChange
do something when an input value changes
nghref
used for adding links
inline templates vs external templates vs internal templates
data:image/s3,"s3://crabby-images/f28cb/f28cb74e3cd93c2174008b533a813b6a3500ea51" alt=""
services vs factories vs providers
both of them are used to share data across controllers
the syntax is however different for both
Substitutable objects that can be wired together using DI.
· Use services to share code and data across the app.
· Angular Services are lazily initialized (initiates only when its needed)
· Angular Services are singletons per Angular module.
· Angular has many in-built services (starting with $) e.g. $rootScope, $http, $routeProviders etc.
data:image/s3,"s3://crabby-images/730d2/730d20f3aef34f8716cce9b27ac1dcbf4ee226bf" alt=""
$window
Reference to native window object.
$window.alert(“vhjbvkh”);
$location
data:image/s3,"s3://crabby-images/f8771/f877157d7fda2eda10c9bd5063b84f313f1b64d6" alt=""
$document
jQuery/jqLite wrapper for window.document
$document[0].title
data:image/s3,"s3://crabby-images/80294/802945b982315a8ac1371ee48beb58e1f267978c" alt=""
$timeout
data:image/s3,"s3://crabby-images/e6b4e/e6b4e0f84bcf0e843064e7d16b424727aab344e6" alt=""
$interval
data:image/s3,"s3://crabby-images/f283f/f283fc0198e2f4c9c7d3b351786f873530b83490" alt=""
$templateCache
data:image/s3,"s3://crabby-images/e10ce/e10cee22f14da03017af044e50ff2b384c775394" alt=""
$http.post vs jquery.post
data:image/s3,"s3://crabby-images/9227e/9227e00221e0527a74252c1d7a0bc9cd9c197be3" alt=""
what is routing?
data:image/s3,"s3://crabby-images/16b07/16b074c4f40945b3499312c4e3bbaca59c87a887" alt=""
$routeProvider and ngRoute
it can be injected as a parameter, while implementing routing in our application;
ngRoute module is or can be injected into our app
promise
http service - we make async rqst to server; using ‘get’ method for example - we can get or fetch json data from the server; this request returns a promise object with .success() and .error(); if we tell $http to fetch json , the result will be automatically be decoded into JS objects and arrays; $http returns a promise, so success() gets the data …
links
or example we are creating a note-taking app; if we hover over a note - we want to display the description; so we need jquery; so how do we do this? We use links to attach or put th jquery code into the directive; This is the best spot to do any DOM manipulation or logic functionality for your directive; the three automatically injected parameters are scope, element (refers to outermost element of the included template) and attribute (refers to the attributes on the directive element);
isolate scope
By passing an object to the scope option, you are creating an isolate scope. This tells the directive to keep scope inside of itself and not to inherit or share with other scopes.
$scope vs isolate scope
$scope - Allows you to set values as properties on our scope object.
scope: { } - Allows you to create an isolate scope private to this directive.
scope bindings
- Text Binding (Prefix: @) | Parsed as string and one-way binding
- One-way Binding (Prefix: &) | defined as getter functions and read-only inside directive’s scope
- Two-way Binding (Prefix: =) | Can be changed inside directive and reflects outside as well