SlideShare a Scribd company logo
Building Better AngularJS
1.x Apps With TypeScript
KURT WIERSMA
@KWIERSMA
+
Who am I?
From Minneapolis, MN

Work for the American Academy of Neurology

Have been developing web apps for over 15 years

Favorites: Python/Django, AngularJS, TypeScript,
C#/MVC
Agenda
TypeScript intro and getting started

AngularJS basic knowledge assumed

How to combine two great tools

App config, routes, references.ts ordering

Controllers

Services

Authentication with API’s

Authorization and routes
AWESOME, INC
PROJECT
DATE CLIENT
8/1/2015
TypeScript
A RISING STAR
http://typescriptlang.org

TypeScript lets you write JavaScript the way you
really want to.

TypeScript is a typed superset of JavaScript that
compiles to plain JavaScript.

Any browser. Any host. Any OS. Open Source.

AngularJS 2 is implemented in TypeScript
JAVASCRIPT IS VALID TYPESCRIPT
TypeScript Syntax
Features
Classes

Modules

Interfaces

Generics

Arrow Functions

References

Type Definitions

Better “this” by default
Why would you want
types?
Structure for large code bases and/or teams

Catch errors early

Provide a structured API

Tooling can provide better code completion &
refactoring
What about existing
JavaScript Libraries?
DefinitelyTyped provides TS definitions for tons of
JS libraries

JQuery, Angular, Node, Ember, Backbone, ect.

http://definitelytyped.org

You can write you own definitions easily

TSD or Typings used to manage definitions
Custom Definitions
pusher.d.ts
Useage
Getting Started
Install: 

npm install -g typescript
Compile: 

tsc --sourcemap --out js/Application.js js/
_all.ts
Tooling
CLI: grunt with grunt-ts or gulp

TSD: managing definitions for JS libraries

tsd install angular --resolve --overwrite --save
IDEs: 

WebStorm / IntelliJ (Mac & Win) [$]

Visual Studio 2012+ (Win) [$]

Visual Studio Code (Mac & Win) [Free]

Eclipse (Mac & Win) [Free]

Editors: 

Sublime [$]

Atom [Free]
TYPSCRIPT COMPILE
GruntFile.JS
AWESOME, INC
PROJECT
DATE CLIENT
4/1/2010
AngularJS
A SUPER HEROIC FRAMEWORK
APP CONFIG & ROUTES
Application.ts
CONTROLLERS
SERVICES
AUTHENTICATION WITH API’S
AUTHORIZATION & ROUTES
Application.ts
Services.js
AngularJS Tools
Debugging

Batarang

ng-inspector

AngularUI & Bootstrap UI

Testing

Protractor

ng-describe
Resources
Using Visual Studio Code with Typescript and
AngularJS

John Papa’s AngularJS Style Guide

Real World Example Apps

Angular In 20 Minutes

Expense Manager
QUESTIONS?
KURT WIERSMA (KWIERSMA@MAC.COM)
@KWIERSMA
HTTP://GITHUB.COM/KWIERSMA

More Related Content

PPTX
Angular TS(typescript)
PDF
Launch Yourself into The AngularJS 2 And TypeScript Space
PPTX
Consuming Restful APIs using Swagger v2.0
PDF
Documenting your REST API with Swagger - JOIN 2014
PDF
Implement Web API with Swagger
PPTX
Swagger in the API Lifecycle
PPTX
Swagger - make your API accessible
PDF
Android clean architecture workshop 3h edition
Angular TS(typescript)
Launch Yourself into The AngularJS 2 And TypeScript Space
Consuming Restful APIs using Swagger v2.0
Documenting your REST API with Swagger - JOIN 2014
Implement Web API with Swagger
Swagger in the API Lifecycle
Swagger - make your API accessible
Android clean architecture workshop 3h edition

What's hot (20)

PPTX
Building APIs with Node.js and Swagger
PPTX
Rest API with Swagger and NodeJS
PDF
Angular js - 10 reasons to choose angularjs
PDF
Streamlining API with Swagger.io
PPTX
Writer APIs in Java faster with Swagger Inflector
PPTX
Introducing swagger
PDF
OpenAPI development with Python
PPTX
Understanding how to use Swagger and its tools
PDF
Mobile automation using selenium cucumber & appium
PDF
Swagger for-your-api
PPTX
React Native.pptx (2)
PDF
J-Spring 2018 - Angular for Java developers
PDF
OpenValue meetup July 2018 - Angular for Java developers
PDF
Code Nomads meetup June 2018 - Angular for Java developers
PDF
Design Driven API Development
PDF
Tweakers Developers Summit 2019 - Angular for backend developers
PPTX
Gdg makurdi
PPTX
Introducing Swagger
PPTX
Swagger APIs for Humans and Robots (Gluecon)
Building APIs with Node.js and Swagger
Rest API with Swagger and NodeJS
Angular js - 10 reasons to choose angularjs
Streamlining API with Swagger.io
Writer APIs in Java faster with Swagger Inflector
Introducing swagger
OpenAPI development with Python
Understanding how to use Swagger and its tools
Mobile automation using selenium cucumber & appium
Swagger for-your-api
React Native.pptx (2)
J-Spring 2018 - Angular for Java developers
OpenValue meetup July 2018 - Angular for Java developers
Code Nomads meetup June 2018 - Angular for Java developers
Design Driven API Development
Tweakers Developers Summit 2019 - Angular for backend developers
Gdg makurdi
Introducing Swagger
Swagger APIs for Humans and Robots (Gluecon)
Ad

Similar to Building Better AngularJS 1.X Apps With TypeScript (20)

PPTX
quantum_leap_angularjs_tools_redefining_development_in_2023.pptx
PPTX
angular.pptx
PDF
quantum_leap_angularjs_tools_redefining_development_in_2023.pdf
PDF
Integrating TypeScript with popular frameworks like React or Angular.pdf
PDF
Introduction to Angular for .NET Developers
PPTX
Big Improvement_ New AngularJS Tools Changing How We Develop.pptx
PDF
How TypeScript App Development is Important.pdf
PDF
Angular Roadmap For Beginner PDF By ScholarHat.pdf
PPTX
Angular Vs React Vs Vue.pptx
PDF
Big Improvement_ New AngularJS Tools Changing How We Develop.pdf
PPTX
Benefits of AngularJS Development for Your Business - APPNWEB Technologies
PDF
Reasons to Use Typescript for Your Next Project Over Javascript.pdf
PDF
User Testing in the Invisible World of APIs
PDF
Introduction to Angular for .NET Developers
PDF
Building REST APIs that don't suck for modern day SPAs
PDF
The UX of DX: User Testing in the Invisible World of APIs
PDF
Difference Between Angular and AngularJS.pdf
PDF
PDF
Introduction to Angular for .NET Developers
quantum_leap_angularjs_tools_redefining_development_in_2023.pptx
angular.pptx
quantum_leap_angularjs_tools_redefining_development_in_2023.pdf
Integrating TypeScript with popular frameworks like React or Angular.pdf
Introduction to Angular for .NET Developers
Big Improvement_ New AngularJS Tools Changing How We Develop.pptx
How TypeScript App Development is Important.pdf
Angular Roadmap For Beginner PDF By ScholarHat.pdf
Angular Vs React Vs Vue.pptx
Big Improvement_ New AngularJS Tools Changing How We Develop.pdf
Benefits of AngularJS Development for Your Business - APPNWEB Technologies
Reasons to Use Typescript for Your Next Project Over Javascript.pdf
User Testing in the Invisible World of APIs
Introduction to Angular for .NET Developers
Building REST APIs that don't suck for modern day SPAs
The UX of DX: User Testing in the Invisible World of APIs
Difference Between Angular and AngularJS.pdf
Introduction to Angular for .NET Developers
Ad

More from ColdFusionConference (20)

PDF
Api manager preconference
PDF
PDF
Building better SQL Server Databases
PDF
API Economy, Realizing the Business Value of APIs
PDF
Don't just pdf, Smart PDF
PDF
Crafting ColdFusion Applications like an Architect
PDF
Security And Access Control For APIS using CF API Manager
PDF
Monetizing Business Models: ColdFusion and APIS
PDF
Become a Security Rockstar with ColdFusion 2016
PDF
ColdFusion in Transit action
PDF
Developer Insights for Application Upgrade to ColdFusion 2016
PDF
Where is cold fusion headed
PDF
ColdFusion Keynote: Building the Agile Web Since 1995
PDF
Instant ColdFusion with Vagrant
PPT
Restful services with ColdFusion
PDF
Super Fast Application development with Mura CMS
PDF
Build your own secure and real-time dashboard for mobile and web
PDF
Why Everyone else writes bad code
PDF
Securing applications
PDF
Testing automaton
Api manager preconference
Building better SQL Server Databases
API Economy, Realizing the Business Value of APIs
Don't just pdf, Smart PDF
Crafting ColdFusion Applications like an Architect
Security And Access Control For APIS using CF API Manager
Monetizing Business Models: ColdFusion and APIS
Become a Security Rockstar with ColdFusion 2016
ColdFusion in Transit action
Developer Insights for Application Upgrade to ColdFusion 2016
Where is cold fusion headed
ColdFusion Keynote: Building the Agile Web Since 1995
Instant ColdFusion with Vagrant
Restful services with ColdFusion
Super Fast Application development with Mura CMS
Build your own secure and real-time dashboard for mobile and web
Why Everyone else writes bad code
Securing applications
Testing automaton

Recently uploaded (20)

PDF
Empathic Computing: Creating Shared Understanding
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Machine learning based COVID-19 study performance prediction
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
PDF
Modernizing your data center with Dell and AMD
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Spectral efficient network and resource selection model in 5G networks
PDF
Unlocking AI with Model Context Protocol (MCP)
PPTX
Big Data Technologies - Introduction.pptx
PDF
Encapsulation theory and applications.pdf
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Approach and Philosophy of On baking technology
PPTX
MYSQL Presentation for SQL database connectivity
PPT
Teaching material agriculture food technology
Empathic Computing: Creating Shared Understanding
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Machine learning based COVID-19 study performance prediction
Diabetes mellitus diagnosis method based random forest with bat algorithm
CIFDAQ's Market Insight: SEC Turns Pro Crypto
The Rise and Fall of 3GPP – Time for a Sabbatical?
Modernizing your data center with Dell and AMD
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Spectral efficient network and resource selection model in 5G networks
Unlocking AI with Model Context Protocol (MCP)
Big Data Technologies - Introduction.pptx
Encapsulation theory and applications.pdf
Per capita expenditure prediction using model stacking based on satellite ima...
The AUB Centre for AI in Media Proposal.docx
Understanding_Digital_Forensics_Presentation.pptx
“AI and Expert System Decision Support & Business Intelligence Systems”
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Approach and Philosophy of On baking technology
MYSQL Presentation for SQL database connectivity
Teaching material agriculture food technology

Building Better AngularJS 1.X Apps With TypeScript