SlideShare a Scribd company logo
Angular.JS
Advanced Angular.JS - GDayX VN 2013
About me
Nicolas Embleton, French in Ho Chi Minh City
•
•
•
•

2005 - Software Engineer and System Architect, working on legacy tech
stacks (C++, OpenGL, Java, ...) then quickly Web (PHP)
2009 - Founded a Mobile Development Company of 30 individuals
2011 - Started Datafield Startup, Co-founder, CTO
2013 - Started the Javascript Ho Chi Minh City meetup, Getting active in
Startup Vietnamese scene to support and mentor young talents
Agenda

•
•
•
•
•
•
•
•

Quick Intro
Bootstrapping
Why Angular?
Main features, and why it's awesome
Best practices
Testing, tooling
And SEO?
Final words
Intro (quick)
From Wikipedia:

AngularJS is built around the belief that declarative programming

should be used for

building UIs and

wiring software components, while imperative programming is excellent for expressing business
logic. The framework adapts and extends traditional HTML to better serve dynamic content through two-way
data-binding that allows for the automatic synchronization of models and views. As a result, AngularJS deemphasizes
DOM manipulation and improves testability.
Angular JS quick review

•
•
•
•
•
•
•

Templating
Model View Controller (MVC)
Extends HTML (very flexible)
2-ways Data-binding
Very reusable (if you follow best practices)
Improves testability (because it is reusable)
Provides routing, history, jqLite, ...
Bootstrapping

•

Using angular-seeds

•

Using yeoman (excellent workflow tool)

o git clone https://github.com/angular/angular-seed.git
o node scripts/web-server.js
o open http://localhost:8000/app/index.html

o
o
o
o
o

(sudo) npm install -g yo
(sudo) npm install -g generator-angular
yo angular
bower install angular-ui
grunt server
Now, the meat, the main features

•
•
•
•
•
•

Templating
Routing
2-ways data-binding
Directives, services
Dependency Injection
Inter-components Communication
Templating

•

Models

•

Built-in directives

2-way binding
o Easy property mapping
o

ngView
 Where the routing happens
o ngRepeat
 Iterator
o ngIf
o ngSwitch
o
Templating - Conditional with ngIf
<div ng-repeat="message in data.messages" ng-class="message.type">
<hr>
<div ng-if="showFrom(message)">
<div>From: {{message.from.name}}</div>
</div>
<div ng-if="showCreatedBy(message)">
<div>Created by: {{message.createdBy.name}}</div>
</div>
<div ng-if="showTo(message)">
<div>To: {{message.to.name}}</div>
</div>
</div>​
Templating - Nested repeat
<div ng-repeat="group in groups"><!-- 1st ng-repeat level -->
<h2>{{ group.label }}</h2>
<ul>
<li ng-repeat="friend in group.friends">
<!-- 2nd ng-repeat level -->
{{ friend.name }}
</li>
</ul><!-- END: Inner ngRepeat. -->
</div><!-- END: Outer ngRepeat. -->​
Templating - Example 2 - Switch
<div ng-switch on="selection" >
<div ng-switch-when="settings">Settings Div</div>
<span ng-switch-when="home">Home Span</span>
<span ng-switch-default>default</span>
</div>​
Example 2.2 - Switch with 2-way
bind
<div ng-controller="Ctrl">
<select ng-model="selection" ng-options="item for item in items">
</select>
<tt>selection={{selection}}</tt>
<hr/>
<div class="animate-switch-container"
ng-switch on="selection">
<div ng-switch-when="settings">Settings Div</div>
<div ng-switch-when="home">Home Span</div>
<div ng-switch-default>default</div>
</div>
</div>
Templating - Simple ngRepeat
<li ng-repeat="item in items">
Item: {{ item }}
</li>
Templating - Complex ngRepeat
<header ng-repeat-start="item in items">
Header {{ item }}
</header>
<div class="body">
Body {{ item }}
</div>
<footer ng-repeat-end>
Footer {{ item }}
</footer>
Compiling
// compile the new DOM and link it to the current scope.
// NOTE: we only compile .childNodes so that
// we don't get into infinite loop compiling ourselves
$compile(element.contents())(scope);
Templating - Routing

•
•
•
•

Happens in ngView
Routing is a very powerful feature
Allows to update "pieces" of the page
Can stream files from disk to make it truly
isolated
2-ways data-binding
•
•
•
•

Becoming more standard, thanks to frameworks like Ember.js or Angular.js

•

Example

Linking 2 fields for synchronization purpose
Linking data to model
Automatically updating the template as data is changed
o Arrays / Collections
o Inputs
o etc…
2-ways data-binding, example
<input type="text" ng-model="title" style="width: 90%"/>
<div ng-app="myapp">
<div ng-controller="mycontroller">
Title: {{ title }} <!-- 2-way data binding -->
<hr>
<div class="zippy" zippy-title="title"></div>
</div>
</div>​
Directives

•
•
•

Angular.js killer feature
Great deal of re-usability
Just look for directives at ngmodules.org
Restricting Directives

•
•
•
•
•

"E": Element, <my-directive>
"A": Attribute, <div my-directive>
"C": Class, <div class="my-directive">
"M": Comment: <!-- directive: my-directive exp -->
Combine (e.g. "EA") for more flexibility
Communicating between directives

•
•

Many design patterns
The "backbonier"

•

A more connected example

o

o

the emitter and the receiver
the directive combinations and controller sharing
Communicating between directives
app.directive('directiveA', function($rootScope){
return function(scope, element, attrs) {

// $rootScope = App Scope
// scope = Current scope (ctrl)

$rootScope.$on('someEvent', function(){
// From here we can react anytime there's an event "someEvent" triggered
});
};
});​
Communicating between directives
app.directive('gdayx', function() { // Creating the directive
return {
restrict: 'E', // Restricted to "element"
controller: function($scope) {
$scope.what = "";

// Creating the controller of the directive

// Local data

this.is = function(what) {

// External accessor

$scope.what = what;
}
},
link: function($scope, $element){
$element.bind("click", function() { // Binding on click
alert("GDayX is "+$scope.what); // Getting content from the Controller.
});
}
}
​

});
Communicating between directives
// This directive will "send" data to the first directive
app.directive('is', function() {

// Creating the directive

return {
require: "gdayx",

// Requiring the "gdayx" controller

restrict: 'A',

// Restricting to "attribute"

link: function(scope, element, attrs, gdayxCtrl) {
// gdayxCtrl from the "require: 'gdayx'"
gdayxCtrl.is(attrs.is); // Passing value to the "gdayx" controller
}
}
});​
AngularJS - Why is it awesome?

•
•
•
•
•

Mature, production-ready
Feature-rich
The design and what it allows
Strong support from giants like Google
A lot of solid companies are embracing it
o
o
o

Ebay Commerce Network
DoubleClick (Google) - Marketing Manager & Planner
YouTube APP on PS3
Best Practices

•
•

Organize the code well (Captain Obvious!)
Organize modules by feature

•
•

Use the reusability as much as possible
Use the testability as much as possible

angular.module('users', ['utilities']);
angular.module('groups', ['utilities']);
angular.module('mainApp', ['users', 'groups']);

o
o

TDD
BDD?
Testing, tooling
•
•
•
•
•
•

Yeoman
o Super workflow tool and generator/scaffolder
Batarang
o Chrome Debugger Extension, (A must have), link
Grunt
o Task runner
Bower
o Package Manager for JS Libraries
Protractor, Karma
o Test Runner
Jasmine, Mocha
o Test Frameworks
And SEO?

•

Google "Snapshot" famous technic
o
o

_escaped_fragment_
Turns this:


o

Into this:


•
•

http://prerender.io/getting-started#html5-pushstate
http://prerender.io/getting-started?
_escaped_fragment_=html5-pushstate

prerender.io/ - Open Source project
brombone.com/ - Commercial project
Enterprise project with Angular?

•
•

YES
BUT
Enterprise project with Angular?

•
•

YES
BUT
o
o
o

Follow best practices (easier said than done)
System Architecture is KEY to a solid system
As "Agile" would advise, always try to go for simpler
but "well-thought" "team-friendly"designs.
Enterprise project with Angular?

•

An example Architecture
Backend
(legacy)

A/B t
esting
?

Legacy Front End

Experimental Front
End

DB
Backend
(experimental)

Server-side team realm

Experimental Front
End 2

Front-End team realm
Final Words

•
•

Angular 1.0.x is mature
Angular 1.2+ will bring more awesomeness
o
o

Better and Fluid Animations (js/css3)
More flexibility and functionalities




$interval: add a service wrapping setInterval
Event directives: add ngCopy, ngCut, and ngPaste
jQuery 1.10.x support
DEMO
(if time permits :)
Bootstrapped app

•
•

Let's see a quick Angular App
Bootstrapped from Yeoman
Where you can find me:
Author: Nicolas Embleton @: nicolas.embleton@gmail.com
Presentation made for “Google Developer Day GDayX 2013 Vietnam”
You can follow me at:
https://plus.google.com/+NicolasEmbleton
https://twitter.com/nicolasembleton

•
•

And the Javascript Ho Chi Minh City Meetup:
http://meetup.com/JavaScript-Ho-Chi-Minh-City/
https://www.facebook.com/JavaScriptHCMC
https://plus.google.com/communities/116105314977285194967

•
•
•

o

Our group is looking for Projects to mentor. If you have a project you want support for, contact
me
Resources
Learning
• Learning AngularJS by the example (+60 minutes-ish training video)
• http://www.nganimate.org/
• https://github.com/angular-ui/ui-router
o It's a full "nested-view" library

• http://docs.angularjs.org/guide/dev_guide.templates.databinding
• ng-learn.org
Reusable Components
• http://ngmodules.org/
• http://www.directiv.es/

More Related Content

PDF
gDayX 2013 - Advanced AngularJS - Nicolas Embleton
PDF
Reactive Type safe Webcomponents with skateJS
PDF
Building an HTML5 Video Player
PPTX
JavaScript Advanced - Useful methods to power up your code
PPT
WordPress and Ajax
KEY
Mobile HTML, CSS, and JavaScript
PDF
Realize mais com HTML 5 e CSS 3 - 16 EDTED - RJ
PDF
HTML 5 - Overview
gDayX 2013 - Advanced AngularJS - Nicolas Embleton
Reactive Type safe Webcomponents with skateJS
Building an HTML5 Video Player
JavaScript Advanced - Useful methods to power up your code
WordPress and Ajax
Mobile HTML, CSS, and JavaScript
Realize mais com HTML 5 e CSS 3 - 16 EDTED - RJ
HTML 5 - Overview

What's hot (20)

PDF
Building Web Sites that Work Everywhere
PPTX
MWLUG 2015 - AD114 Take Your XPages Development to the Next Level
TXT
PDF
[convergese] Adaptive Images in Responsive Web Design
PDF
WordPress-Templates mit Twig erstellen - PHPUGFFM
PDF
jQuery UI and Plugins
PDF
HTML5: where flash isn't needed anymore
PDF
Oleh Zasadnyy "Progressive Web Apps: line between web and native apps become ...
PDF
HTML5: friend or foe (to Flash)?
PPT
High Performance Ajax Applications
PDF
JavaScript Libraries (@Media)
PDF
Keypoints html5
PDF
High-Quality JavaScript
PDF
JavaScript Libraries (Kings of Code)
PDF
High Performance Django
PPTX
PDF
jQuery (DrupalCamp Toronto)
KEY
Wicket 2010
PPT
jQuery For Beginners - jQuery Conference 2009
PDF
Microservices: Improving the autonomy of our teams with Event-Driven Architec...
Building Web Sites that Work Everywhere
MWLUG 2015 - AD114 Take Your XPages Development to the Next Level
[convergese] Adaptive Images in Responsive Web Design
WordPress-Templates mit Twig erstellen - PHPUGFFM
jQuery UI and Plugins
HTML5: where flash isn't needed anymore
Oleh Zasadnyy "Progressive Web Apps: line between web and native apps become ...
HTML5: friend or foe (to Flash)?
High Performance Ajax Applications
JavaScript Libraries (@Media)
Keypoints html5
High-Quality JavaScript
JavaScript Libraries (Kings of Code)
High Performance Django
jQuery (DrupalCamp Toronto)
Wicket 2010
jQuery For Beginners - jQuery Conference 2009
Microservices: Improving the autonomy of our teams with Event-Driven Architec...
Ad

Viewers also liked (6)

PDF
TDD with KnockoutJS
PDF
Testing AngularJS
PDF
29 Essential AngularJS Interview Questions
PDF
Advanced AngularJS Concepts
PDF
A Big Look at MiniTest
PPTX
Building a dashboard using AngularJS
TDD with KnockoutJS
Testing AngularJS
29 Essential AngularJS Interview Questions
Advanced AngularJS Concepts
A Big Look at MiniTest
Building a dashboard using AngularJS
Ad

Similar to gDayX - Advanced angularjs (20)

PDF
Nicolas Embleton, Advanced Angular JS
PDF
GDayX - Advanced Angular.JS
PDF
AngularJs
PDF
Angularjs 131211063348-phpapp01
PPTX
ME vs WEB - AngularJS Fundamentals
PDF
Angular js
PDF
Workshop 12: AngularJS Parte I
PPTX
Angular js 1.3 presentation for fed nov 2014
PDF
PDF
Beginning AngularJS
PPTX
Learning AngularJS - Complete coverage of AngularJS features and concepts
PDF
AngularJS Curriculum-Zeolearn
PPTX
Angular Presentation
PPTX
Angular training - Day 3 - custom directives, $http, $resource, setup with ye...
PPTX
AngularJS with TypeScript and Windows Azure Mobile Services
PPTX
AngularJS.part1
PPTX
AngularJS Introduction (Talk given on Aug 5 2013)
PPT
Angular In Depth
Nicolas Embleton, Advanced Angular JS
GDayX - Advanced Angular.JS
AngularJs
Angularjs 131211063348-phpapp01
ME vs WEB - AngularJS Fundamentals
Angular js
Workshop 12: AngularJS Parte I
Angular js 1.3 presentation for fed nov 2014
Beginning AngularJS
Learning AngularJS - Complete coverage of AngularJS features and concepts
AngularJS Curriculum-Zeolearn
Angular Presentation
Angular training - Day 3 - custom directives, $http, $resource, setup with ye...
AngularJS with TypeScript and Windows Azure Mobile Services
AngularJS.part1
AngularJS Introduction (Talk given on Aug 5 2013)
Angular In Depth

Recently uploaded (20)

PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Encapsulation theory and applications.pdf
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
Big Data Technologies - Introduction.pptx
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PPTX
A Presentation on Artificial Intelligence
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PPT
Teaching material agriculture food technology
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Spectral efficient network and resource selection model in 5G networks
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Mobile App Security Testing_ A Comprehensive Guide.pdf
Encapsulation theory and applications.pdf
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Big Data Technologies - Introduction.pptx
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
A Presentation on Artificial Intelligence
“AI and Expert System Decision Support & Business Intelligence Systems”
Teaching material agriculture food technology
Per capita expenditure prediction using model stacking based on satellite ima...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Review of recent advances in non-invasive hemoglobin estimation
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Spectral efficient network and resource selection model in 5G networks
MYSQL Presentation for SQL database connectivity
Unlocking AI with Model Context Protocol (MCP)
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
How UI/UX Design Impacts User Retention in Mobile Apps.pdf

gDayX - Advanced angularjs

  • 2. About me Nicolas Embleton, French in Ho Chi Minh City • • • • 2005 - Software Engineer and System Architect, working on legacy tech stacks (C++, OpenGL, Java, ...) then quickly Web (PHP) 2009 - Founded a Mobile Development Company of 30 individuals 2011 - Started Datafield Startup, Co-founder, CTO 2013 - Started the Javascript Ho Chi Minh City meetup, Getting active in Startup Vietnamese scene to support and mentor young talents
  • 3. Agenda • • • • • • • • Quick Intro Bootstrapping Why Angular? Main features, and why it's awesome Best practices Testing, tooling And SEO? Final words
  • 4. Intro (quick) From Wikipedia: AngularJS is built around the belief that declarative programming should be used for building UIs and wiring software components, while imperative programming is excellent for expressing business logic. The framework adapts and extends traditional HTML to better serve dynamic content through two-way data-binding that allows for the automatic synchronization of models and views. As a result, AngularJS deemphasizes DOM manipulation and improves testability.
  • 5. Angular JS quick review • • • • • • • Templating Model View Controller (MVC) Extends HTML (very flexible) 2-ways Data-binding Very reusable (if you follow best practices) Improves testability (because it is reusable) Provides routing, history, jqLite, ...
  • 6. Bootstrapping • Using angular-seeds • Using yeoman (excellent workflow tool) o git clone https://github.com/angular/angular-seed.git o node scripts/web-server.js o open http://localhost:8000/app/index.html o o o o o (sudo) npm install -g yo (sudo) npm install -g generator-angular yo angular bower install angular-ui grunt server
  • 7. Now, the meat, the main features • • • • • • Templating Routing 2-ways data-binding Directives, services Dependency Injection Inter-components Communication
  • 8. Templating • Models • Built-in directives 2-way binding o Easy property mapping o ngView  Where the routing happens o ngRepeat  Iterator o ngIf o ngSwitch o
  • 9. Templating - Conditional with ngIf <div ng-repeat="message in data.messages" ng-class="message.type"> <hr> <div ng-if="showFrom(message)"> <div>From: {{message.from.name}}</div> </div> <div ng-if="showCreatedBy(message)"> <div>Created by: {{message.createdBy.name}}</div> </div> <div ng-if="showTo(message)"> <div>To: {{message.to.name}}</div> </div> </div>​
  • 10. Templating - Nested repeat <div ng-repeat="group in groups"><!-- 1st ng-repeat level --> <h2>{{ group.label }}</h2> <ul> <li ng-repeat="friend in group.friends"> <!-- 2nd ng-repeat level --> {{ friend.name }} </li> </ul><!-- END: Inner ngRepeat. --> </div><!-- END: Outer ngRepeat. -->​
  • 11. Templating - Example 2 - Switch <div ng-switch on="selection" > <div ng-switch-when="settings">Settings Div</div> <span ng-switch-when="home">Home Span</span> <span ng-switch-default>default</span> </div>​
  • 12. Example 2.2 - Switch with 2-way bind <div ng-controller="Ctrl"> <select ng-model="selection" ng-options="item for item in items"> </select> <tt>selection={{selection}}</tt> <hr/> <div class="animate-switch-container" ng-switch on="selection"> <div ng-switch-when="settings">Settings Div</div> <div ng-switch-when="home">Home Span</div> <div ng-switch-default>default</div> </div> </div>
  • 13. Templating - Simple ngRepeat <li ng-repeat="item in items"> Item: {{ item }} </li>
  • 14. Templating - Complex ngRepeat <header ng-repeat-start="item in items"> Header {{ item }} </header> <div class="body"> Body {{ item }} </div> <footer ng-repeat-end> Footer {{ item }} </footer>
  • 15. Compiling // compile the new DOM and link it to the current scope. // NOTE: we only compile .childNodes so that // we don't get into infinite loop compiling ourselves $compile(element.contents())(scope);
  • 16. Templating - Routing • • • • Happens in ngView Routing is a very powerful feature Allows to update "pieces" of the page Can stream files from disk to make it truly isolated
  • 17. 2-ways data-binding • • • • Becoming more standard, thanks to frameworks like Ember.js or Angular.js • Example Linking 2 fields for synchronization purpose Linking data to model Automatically updating the template as data is changed o Arrays / Collections o Inputs o etc…
  • 18. 2-ways data-binding, example <input type="text" ng-model="title" style="width: 90%"/> <div ng-app="myapp"> <div ng-controller="mycontroller"> Title: {{ title }} <!-- 2-way data binding --> <hr> <div class="zippy" zippy-title="title"></div> </div> </div>​
  • 19. Directives • • • Angular.js killer feature Great deal of re-usability Just look for directives at ngmodules.org
  • 20. Restricting Directives • • • • • "E": Element, <my-directive> "A": Attribute, <div my-directive> "C": Class, <div class="my-directive"> "M": Comment: <!-- directive: my-directive exp --> Combine (e.g. "EA") for more flexibility
  • 21. Communicating between directives • • Many design patterns The "backbonier" • A more connected example o o the emitter and the receiver the directive combinations and controller sharing
  • 22. Communicating between directives app.directive('directiveA', function($rootScope){ return function(scope, element, attrs) { // $rootScope = App Scope // scope = Current scope (ctrl) $rootScope.$on('someEvent', function(){ // From here we can react anytime there's an event "someEvent" triggered }); }; });​
  • 23. Communicating between directives app.directive('gdayx', function() { // Creating the directive return { restrict: 'E', // Restricted to "element" controller: function($scope) { $scope.what = ""; // Creating the controller of the directive // Local data this.is = function(what) { // External accessor $scope.what = what; } }, link: function($scope, $element){ $element.bind("click", function() { // Binding on click alert("GDayX is "+$scope.what); // Getting content from the Controller. }); } } ​ });
  • 24. Communicating between directives // This directive will "send" data to the first directive app.directive('is', function() { // Creating the directive return { require: "gdayx", // Requiring the "gdayx" controller restrict: 'A', // Restricting to "attribute" link: function(scope, element, attrs, gdayxCtrl) { // gdayxCtrl from the "require: 'gdayx'" gdayxCtrl.is(attrs.is); // Passing value to the "gdayx" controller } } });​
  • 25. AngularJS - Why is it awesome? • • • • • Mature, production-ready Feature-rich The design and what it allows Strong support from giants like Google A lot of solid companies are embracing it o o o Ebay Commerce Network DoubleClick (Google) - Marketing Manager & Planner YouTube APP on PS3
  • 26. Best Practices • • Organize the code well (Captain Obvious!) Organize modules by feature • • Use the reusability as much as possible Use the testability as much as possible angular.module('users', ['utilities']); angular.module('groups', ['utilities']); angular.module('mainApp', ['users', 'groups']); o o TDD BDD?
  • 27. Testing, tooling • • • • • • Yeoman o Super workflow tool and generator/scaffolder Batarang o Chrome Debugger Extension, (A must have), link Grunt o Task runner Bower o Package Manager for JS Libraries Protractor, Karma o Test Runner Jasmine, Mocha o Test Frameworks
  • 28. And SEO? • Google "Snapshot" famous technic o o _escaped_fragment_ Turns this:  o Into this:  • • http://prerender.io/getting-started#html5-pushstate http://prerender.io/getting-started? _escaped_fragment_=html5-pushstate prerender.io/ - Open Source project brombone.com/ - Commercial project
  • 29. Enterprise project with Angular? • • YES BUT
  • 30. Enterprise project with Angular? • • YES BUT o o o Follow best practices (easier said than done) System Architecture is KEY to a solid system As "Agile" would advise, always try to go for simpler but "well-thought" "team-friendly"designs.
  • 31. Enterprise project with Angular? • An example Architecture Backend (legacy) A/B t esting ? Legacy Front End Experimental Front End DB Backend (experimental) Server-side team realm Experimental Front End 2 Front-End team realm
  • 32. Final Words • • Angular 1.0.x is mature Angular 1.2+ will bring more awesomeness o o Better and Fluid Animations (js/css3) More flexibility and functionalities    $interval: add a service wrapping setInterval Event directives: add ngCopy, ngCut, and ngPaste jQuery 1.10.x support
  • 34. Bootstrapped app • • Let's see a quick Angular App Bootstrapped from Yeoman
  • 35. Where you can find me: Author: Nicolas Embleton @: nicolas.embleton@gmail.com Presentation made for “Google Developer Day GDayX 2013 Vietnam” You can follow me at: https://plus.google.com/+NicolasEmbleton https://twitter.com/nicolasembleton • • And the Javascript Ho Chi Minh City Meetup: http://meetup.com/JavaScript-Ho-Chi-Minh-City/ https://www.facebook.com/JavaScriptHCMC https://plus.google.com/communities/116105314977285194967 • • • o Our group is looking for Projects to mentor. If you have a project you want support for, contact me
  • 36. Resources Learning • Learning AngularJS by the example (+60 minutes-ish training video) • http://www.nganimate.org/ • https://github.com/angular-ui/ui-router o It's a full "nested-view" library • http://docs.angularjs.org/guide/dev_guide.templates.databinding • ng-learn.org Reusable Components • http://ngmodules.org/ • http://www.directiv.es/