SlideShare a Scribd company logo
@kylehodgson
www.kylehodgson.com
Advanced AngularJS Concepts
+
AngularJS
Architectural Advice
Big Ball of Mud
Avoid binding
to functions
DOM
Manipulation
Isolate Scope
Directives
Isolate scope
Isolate scope
Isolate scope
←fail
Isolate scope
← amaze
Isolate scope: Attributes
Directives
Isolate scope
Isolate scope: attributes
← attribute
attribute
Isolate scope: attributes
attribute
Isolate scope: attributes
Bindings
Isolate scope
@:	
  attribute
=:	
  binding
&:	
  expression
Expressions
Isolate scope
Isolate scope: expressions
← expression
Isolate scope: expressions
← expression
Isolate scope: expressions
expression
Isolate scope: expressions
Isolate scope: expressions
Accessibility
AngularJS & the ADA
ADA & AngularJS
“double you double you
double you dot yahoo dot
com slash is not available h t
m l content search search ten
percent text ten percent
loaded”
ADA & AngularJS
Consider not
making an SPA
ADA & AngularJS
Bake it in from
the start
ADA & AngularJS
Keep things
simple
Use ARIA Effectively
ADA & AngularJS
Detection &
Affordance
ADA & AngularJS
ADA & AngularJS
SEO
Issues & solutions
SEO & AngularJS
SEO & AngularJS
Duck Angular
Angular Integration Testing
Advanced AngularJS Concepts
Duck Angular
Run it in Karma
Get it with Bower
bower install duck-angular
Duck Angular & Karma
Toy App: ToDontList
Story Epic
As a busy executive with too much to do,
I would like to see a list of things that are not
worth my time,
So that I can avoid doing them.
Advanced AngularJS Concepts
App.js
Advanced AngularJS Concepts
Duck Angular: Bindings
Duck Angular: Interactions
Duck Angular: Directives
Duck Angular: Bindings
Anatomy of a Duck Angular spec
Duck Angular
Advanced AngularJS Concepts
End to End Testing
AngularJS
E2E
http://docs.angularjs.org/guide/e2e-testing
sic: ‘depricated’ is misspelled on angularjs.org
Selenium
• Mature
• Well understood
• “Enterprise strength”
• Terrible “SPA” support
Protractor
Functional Testing for AngularJS
https://github.com/angular/protractor
Protractor
Not good (with) Karma.
searches for elements by matching
binding names, either from ng-bind
or {{}} notation in the template
by.binding
by.model
by.model searches for elements by
input ng-model
Advanced AngularJS Concepts
by.repeater
by.repeater searches for ng-repeat
elements.
Advanced AngularJS Concepts
Putting it all together
Web server
Selenium
Java
Protractor pre-reqs
Questions?
Kyle Hodgson
www.kylehodgson.com @kylehodgson
Avishek “Mojo” Sen Gupta
www.avishek.net
@avisheksengupta
www.angularjs.org
www.yearofmoo.com
www.egghead.io
www.pluralsight.com
github.com/asengupta/duck-angular
github.com/kylehodgson/angular-toy

More Related Content

PDF
Testing AngularJS
Kyle Hodgson
 
PPTX
AngularJS is awesome
Eusebiu Schipor
 
PPTX
Introduction to Angular 2
Tuan Trung Vo
 
PPTX
Angular 2
Nigam Goyal
 
PDF
Angular Best Practices v2
Henry Tao
 
PPTX
Get satrted angular js
Alexandre Marreiros
 
PDF
Gettings started with the superheroic JavaScript library AngularJS
Armin Vieweg
 
PPTX
PPT on Angular 2 Development Tutorial
Paddy Lock
 
Testing AngularJS
Kyle Hodgson
 
AngularJS is awesome
Eusebiu Schipor
 
Introduction to Angular 2
Tuan Trung Vo
 
Angular 2
Nigam Goyal
 
Angular Best Practices v2
Henry Tao
 
Get satrted angular js
Alexandre Marreiros
 
Gettings started with the superheroic JavaScript library AngularJS
Armin Vieweg
 
PPT on Angular 2 Development Tutorial
Paddy Lock
 

What's hot (20)

PPTX
Angularjs PPT
Amit Baghel
 
PDF
What is Angular version 4?
Troy Miles
 
PDF
Angular js best practice
Matteo Scandolo
 
PDF
AngularJS best-practices
Henry Tao
 
PPTX
Angular js tutorial slides
samhelman
 
PPTX
AngularJs advanced Topics
Amr Abd El Latief
 
PDF
Angularjs tutorial
HarikaReddy115
 
PPTX
Introduction to AngularJS Framework
Raveendra R
 
PDF
AngularJS for Beginners
Edureka!
 
PPTX
Single Page Applications in SharePoint with Angular
Sparkhound Inc.
 
PDF
Quick Way to work with Models and Alloy in Appcelerator Titanium
Aaron Saunders
 
PDF
AngularJS Introduction
Carlos Morales
 
PDF
AngularJS
Hiten Pratap Singh
 
PDF
Developing a Demo Application with Angular 4 - J2I
Nader Debbabi
 
PPTX
Introduction to Angular js 2.0
Nagaraju Sangam
 
PPTX
AngularJs Basic Concept
Hari Haran
 
PDF
The Ultimate Getting Started with Angular Workshop - Devoxx UK 2017
Matt Raible
 
PPTX
Modules in AngularJs
K Arunkumar
 
PPTX
Angular Js
Knoldus Inc.
 
Angularjs PPT
Amit Baghel
 
What is Angular version 4?
Troy Miles
 
Angular js best practice
Matteo Scandolo
 
AngularJS best-practices
Henry Tao
 
Angular js tutorial slides
samhelman
 
AngularJs advanced Topics
Amr Abd El Latief
 
Angularjs tutorial
HarikaReddy115
 
Introduction to AngularJS Framework
Raveendra R
 
AngularJS for Beginners
Edureka!
 
Single Page Applications in SharePoint with Angular
Sparkhound Inc.
 
Quick Way to work with Models and Alloy in Appcelerator Titanium
Aaron Saunders
 
AngularJS Introduction
Carlos Morales
 
Developing a Demo Application with Angular 4 - J2I
Nader Debbabi
 
Introduction to Angular js 2.0
Nagaraju Sangam
 
AngularJs Basic Concept
Hari Haran
 
The Ultimate Getting Started with Angular Workshop - Devoxx UK 2017
Matt Raible
 
Modules in AngularJs
K Arunkumar
 
Angular Js
Knoldus Inc.
 
Ad

Viewers also liked (15)

PDF
29 Essential AngularJS Interview Questions
Arc & Codementor
 
PDF
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
PDF
Angular 2 interview questions and answers
Anil Singh
 
PPTX
Building a dashboard using AngularJS
RajthilakMCA
 
PDF
Secure PIN Management How to Issue and Change PINs Securely over the Web
SafeNet
 
PDF
Information från Läkemedelsverket #5 2013
Läkemedelsverket (Medical Products Agency, Sweden)
 
PPT
"15 Business Story Ideas to Jump on Now"
Reynolds Center for Business Journalism
 
PPTX
Diarrhea:Myths and facts, Precaution
Wuzna Haroon
 
PDF
Enterprise workspaces - Extending SAP NetWeaver Portal capabilities
SAP Portal
 
PDF
Basics of Coding in Pediatrics Medical Billing
Outsource Strategies International
 
PDF
Alta White Paper D2C eCommerce Case Study 2016
Patrick Nicholson
 
PDF
mpx Replay, Expedite Your Catch-Up and C3 Workflow 2 of 2
thePlatform
 
PPTX
Nt1310 project
Nathan Pennington
 
PPTX
Credit cards
ThePointsGuy
 
PDF
Energy Strategy Group_Report 2012 efficienza energetica
Eugenio Bacile di Castiglione
 
29 Essential AngularJS Interview Questions
Arc & Codementor
 
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
Angular 2 interview questions and answers
Anil Singh
 
Building a dashboard using AngularJS
RajthilakMCA
 
Secure PIN Management How to Issue and Change PINs Securely over the Web
SafeNet
 
Information från Läkemedelsverket #5 2013
Läkemedelsverket (Medical Products Agency, Sweden)
 
"15 Business Story Ideas to Jump on Now"
Reynolds Center for Business Journalism
 
Diarrhea:Myths and facts, Precaution
Wuzna Haroon
 
Enterprise workspaces - Extending SAP NetWeaver Portal capabilities
SAP Portal
 
Basics of Coding in Pediatrics Medical Billing
Outsource Strategies International
 
Alta White Paper D2C eCommerce Case Study 2016
Patrick Nicholson
 
mpx Replay, Expedite Your Catch-Up and C3 Workflow 2 of 2
thePlatform
 
Nt1310 project
Nathan Pennington
 
Credit cards
ThePointsGuy
 
Energy Strategy Group_Report 2012 efficienza energetica
Eugenio Bacile di Castiglione
 
Ad

Recently uploaded (20)

PDF
49784907924775488180_LRN2959_Data_Pump_23ai.pdf
Abilash868456
 
PDF
lesson-2-rules-of-netiquette.pdf.bshhsjdj
jasmenrojas249
 
PDF
Exploring AI Agents in Process Industries
amoreira6
 
PDF
49785682629390197565_LRN3014_Migrating_the_Beast.pdf
Abilash868456
 
PDF
Teaching Reproducibility and Embracing Variability: From Floating-Point Exper...
University of Rennes, INSA Rennes, Inria/IRISA, CNRS
 
PDF
Micromaid: A simple Mermaid-like chart generator for Pharo
ESUG
 
PPTX
AI-Ready Handoff: Auto-Summaries & Draft Emails from MQL to Slack in One Flow
bbedford2
 
PDF
Microsoft Teams Essentials; The pricing and the versions_PDF.pdf
Q-Advise
 
PDF
IEEE-CS Tech Predictions, SWEBOK and Quantum Software: Towards Q-SWEBOK
Hironori Washizaki
 
PPTX
Why Use Open Source Reporting Tools for Business Intelligence.pptx
Varsha Nayak
 
PPTX
Presentation about variables and constant.pptx
kr2589474
 
PPTX
ConcordeApp: Engineering Global Impact & Unlocking Billions in Event ROI with AI
chastechaste14
 
PPTX
The-Dawn-of-AI-Reshaping-Our-World.pptxx
parthbhanushali307
 
PDF
Appium Automation Testing Tutorial PDF: Learn Mobile Testing in 7 Days
jamescantor38
 
PDF
The Role of Automation and AI in EHS Management for Data Centers.pdf
TECH EHS Solution
 
PPTX
Explanation about Structures in C language.pptx
Veeral Rathod
 
PPTX
slidesgo-unlocking-the-code-the-dynamic-dance-of-variables-and-constants-2024...
kr2589474
 
PPTX
TestNG for Java Testing and Automation testing
ssuser0213cb
 
PDF
Protecting the Digital World Cyber Securit
dnthakkar16
 
PDF
PFAS Reporting Requirements 2026 Are You Submission Ready Certivo.pdf
Certivo Inc
 
49784907924775488180_LRN2959_Data_Pump_23ai.pdf
Abilash868456
 
lesson-2-rules-of-netiquette.pdf.bshhsjdj
jasmenrojas249
 
Exploring AI Agents in Process Industries
amoreira6
 
49785682629390197565_LRN3014_Migrating_the_Beast.pdf
Abilash868456
 
Teaching Reproducibility and Embracing Variability: From Floating-Point Exper...
University of Rennes, INSA Rennes, Inria/IRISA, CNRS
 
Micromaid: A simple Mermaid-like chart generator for Pharo
ESUG
 
AI-Ready Handoff: Auto-Summaries & Draft Emails from MQL to Slack in One Flow
bbedford2
 
Microsoft Teams Essentials; The pricing and the versions_PDF.pdf
Q-Advise
 
IEEE-CS Tech Predictions, SWEBOK and Quantum Software: Towards Q-SWEBOK
Hironori Washizaki
 
Why Use Open Source Reporting Tools for Business Intelligence.pptx
Varsha Nayak
 
Presentation about variables and constant.pptx
kr2589474
 
ConcordeApp: Engineering Global Impact & Unlocking Billions in Event ROI with AI
chastechaste14
 
The-Dawn-of-AI-Reshaping-Our-World.pptxx
parthbhanushali307
 
Appium Automation Testing Tutorial PDF: Learn Mobile Testing in 7 Days
jamescantor38
 
The Role of Automation and AI in EHS Management for Data Centers.pdf
TECH EHS Solution
 
Explanation about Structures in C language.pptx
Veeral Rathod
 
slidesgo-unlocking-the-code-the-dynamic-dance-of-variables-and-constants-2024...
kr2589474
 
TestNG for Java Testing and Automation testing
ssuser0213cb
 
Protecting the Digital World Cyber Securit
dnthakkar16
 
PFAS Reporting Requirements 2026 Are You Submission Ready Certivo.pdf
Certivo Inc
 

Advanced AngularJS Concepts