SlideShare a Scribd company logo
Using TypeScript To Build
Better JavaScript Apps
Kurt Wiersma
@kwiersma
kwiersma@mac.com
Who am I?
• From Minneapolis, MN
• Have been developing web apps for over 14 years
• Have used Python, Groovy, Java, C#, CFML
• Favorites: Python/Django, C#/MVC, AngularJS,
TypeScript
Agenda
• What is TypeScript?
• Syntax
• Getting Started
• Comparisons
• Why would you want types?
• Working with JavaScript libraries
• Tooling
What is TypeScript?
• 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.
• http://typescriptlang.org
Wait, M$ and Open Source?
Are pigs flying now?
JavaScript is Valid TypeScript
TypeScript Syntax
Features
• Classes
• Modules
• Interfaces
• Generics
• Arrow Functions
• References
• Type Definitions
• Better “this” by default
Pros & Cons
Pros
• Syntax much like JS
• Targets ES 6
• Optional Types
• Classes, Generics, Interfaces
• Fixes “this”
Cons
• Compile step
• Debugging (use source maps)
• Another language / tool to
learn
Comparisons
TYPESCRIPT COFFESCRIPT DART ES 6
COMPILED X X X X*
TYPED X X
WHITE SPACE X
JS LIKE
SYNTAX
X 1/2 X
CLASSES X X X X
USE JS
LIBRARIES
X X X
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 tool to manage definitions
Custom Definitions
pusher.d.ts
Useage
Getting Started
• Install:
• npm -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]
Tooling Demo
Making My App Better
• Gradually moved over my JS to TS
• Added types and better structure to code along the
way
• Made working with Angular's API easier to learn
App/Code Demo
Key Points
• Javascript is valid TypeScript
• TypeScript is following ECMA Script 6
• Types are optional
• TypeScript does NOT force you to do classes and
interfaces!
• Refactoring! Tooling!
Real World Example Apps
• Angular In 20 Minutes
• Expense Manager
References
• http://gilamran.blogspot.co.il/2013/07/typescript-on-
production.html
• http://gilamran.blogspot.com/2014/04/typescript-for-
javascripters.html
• http://visualstudiomagazine.com/articles/2013/10/01/
calling-web-services-with-typescript.aspx
Questions?
Kurt Wiersma (kwiersma@mac.com)
@kwiersma
http://github.com/kwiersma

More Related Content

PPTX
TypeScript Jump Start
Mostafa
 
PPTX
Java script fundamental - Introduction to JavaScript Programming Language
Kimsea Sok
 
PPTX
TypeScript Introduction
Travis van der Font
 
PPTX
Typescript overview
Thanvilahari
 
PDF
End-to-End SPA Development using TypeScript
Gil Fink
 
PDF
Getting Started with the TypeScript Language
Gil Fink
 
PPTX
Typescript: JS code just got better!
amit bezalel
 
PPTX
Intro to TypeScript, HTML5DevConf Oct 2013
Matt Harrington
 
TypeScript Jump Start
Mostafa
 
Java script fundamental - Introduction to JavaScript Programming Language
Kimsea Sok
 
TypeScript Introduction
Travis van der Font
 
Typescript overview
Thanvilahari
 
End-to-End SPA Development using TypeScript
Gil Fink
 
Getting Started with the TypeScript Language
Gil Fink
 
Typescript: JS code just got better!
amit bezalel
 
Intro to TypeScript, HTML5DevConf Oct 2013
Matt Harrington
 

What's hot (20)

PPTX
Introduction To Rust Language - Chester Devs
Andy Lowry
 
PPTX
Microfrontends Monoreops & Trunkbased based
Vinci Rufus
 
PPT
Web development basics (Part-7)
Rajat Pratap Singh
 
PPTX
Microsoft Azure DocumentDB - Global Azure Bootcamp 2016
Sunny Sharma
 
PPTX
Java Script Template Engine 비교하기
SeongSik Choi
 
KEY
Introduction to the wonderful world of JavaScript
Jakob Torp
 
PPTX
Next-generation JavaScript - OpenSlava 2014
Oscar Renalias
 
PDF
JavaScript Engine and WebAssembly
Changhwan Yi
 
PPTX
TypeScript: Bringing Sanity to JavaScript
Dave Fancher
 
PPTX
Journey To The Front End World - Part3 - The Machine
Irfan Maulana
 
PDF
Clojure Lightning Talk
GiltTech
 
PDF
WebAssembly vs JavaScript: What is faster?
Alexandr Skachkov
 
PPT
Web development basics (Part-5)
Rajat Pratap Singh
 
PPTX
Introduction To JavaScript Ajax
Reema
 
PDF
Our wish to Flowtype
Teppei Sato
 
PPTX
Web Development: Making it the right way
Yagiz Nizipli
 
PDF
A brief intro to RubyMotion
Kamil Lelonek
 
PDF
NoSQL for great good [hanoi.rb talk]
Huy Do
 
PPTX
Angular4 kickstart
Foyzul Karim
 
PPTX
MEAN stack
Iryney Baran
 
Introduction To Rust Language - Chester Devs
Andy Lowry
 
Microfrontends Monoreops & Trunkbased based
Vinci Rufus
 
Web development basics (Part-7)
Rajat Pratap Singh
 
Microsoft Azure DocumentDB - Global Azure Bootcamp 2016
Sunny Sharma
 
Java Script Template Engine 비교하기
SeongSik Choi
 
Introduction to the wonderful world of JavaScript
Jakob Torp
 
Next-generation JavaScript - OpenSlava 2014
Oscar Renalias
 
JavaScript Engine and WebAssembly
Changhwan Yi
 
TypeScript: Bringing Sanity to JavaScript
Dave Fancher
 
Journey To The Front End World - Part3 - The Machine
Irfan Maulana
 
Clojure Lightning Talk
GiltTech
 
WebAssembly vs JavaScript: What is faster?
Alexandr Skachkov
 
Web development basics (Part-5)
Rajat Pratap Singh
 
Introduction To JavaScript Ajax
Reema
 
Our wish to Flowtype
Teppei Sato
 
Web Development: Making it the right way
Yagiz Nizipli
 
A brief intro to RubyMotion
Kamil Lelonek
 
NoSQL for great good [hanoi.rb talk]
Huy Do
 
Angular4 kickstart
Foyzul Karim
 
MEAN stack
Iryney Baran
 
Ad

Viewers also liked (20)

PDF
International Day of the Girl at the South Bank Centre 2012
Candy Gourlay
 
PDF
Fermars field School_ Facilitation Skill
Tapan Maity
 
PDF
Mobile world 2014
Deepak Raj (2,000+Connections)
 
PPT
พม่า ไทยแลนด์
konthaiuk
 
PPTX
Insight Investments Overview
Allie Kastorff
 
PPT
Skultsje 1 | Wetterwalden Butenfjild | ROC Friese Poort | Centrum Duurzaam
duurzame verhalen
 
PDF
Sex, lies & innovation
mattsadler
 
PPTX
Responsive Website Design
Shamim Reza
 
PPTX
Lançamentos Editora Pensamento Cultrix abril 2016
Milena Cherubim
 
PPTX
Sydney JTBD meetup - the 4 forces of progress
Christian Lafrance
 
PDF
女性のためのキャリアセミナー 自分のためにはたらこう
Rico Sengan
 
PDF
Química computacional - Treball de recerca- Pau Bosch Cabot
Pau Bosch Cabot
 
PDF
Clean code game - Agile France 2013
Michel Domenjoud
 
PDF
The role of creative industries in regeneration
Julian Dobson
 
PDF
Cours introduction au contrat de travail en Belgique
Prof. Jacques Folon (Ph.D)
 
PDF
AMP Accelerated Mobile Pages - Getting Started & Analytics
Vincent Koc
 
PDF
Gen Z - Insights
Romain
 
PDF
Janab e Sayeda* Ki Manzoom Kahani - Vajahat Mirza Changezi
Jamal Mirza
 
PPT
Historia y clasificación celular
Giuliana Tinoco
 
PDF
Metadata and the Power of Pattern-Finding
DATAVERSITY
 
International Day of the Girl at the South Bank Centre 2012
Candy Gourlay
 
Fermars field School_ Facilitation Skill
Tapan Maity
 
พม่า ไทยแลนด์
konthaiuk
 
Insight Investments Overview
Allie Kastorff
 
Skultsje 1 | Wetterwalden Butenfjild | ROC Friese Poort | Centrum Duurzaam
duurzame verhalen
 
Sex, lies & innovation
mattsadler
 
Responsive Website Design
Shamim Reza
 
Lançamentos Editora Pensamento Cultrix abril 2016
Milena Cherubim
 
Sydney JTBD meetup - the 4 forces of progress
Christian Lafrance
 
女性のためのキャリアセミナー 自分のためにはたらこう
Rico Sengan
 
Química computacional - Treball de recerca- Pau Bosch Cabot
Pau Bosch Cabot
 
Clean code game - Agile France 2013
Michel Domenjoud
 
The role of creative industries in regeneration
Julian Dobson
 
Cours introduction au contrat de travail en Belgique
Prof. Jacques Folon (Ph.D)
 
AMP Accelerated Mobile Pages - Getting Started & Analytics
Vincent Koc
 
Gen Z - Insights
Romain
 
Janab e Sayeda* Ki Manzoom Kahani - Vajahat Mirza Changezi
Jamal Mirza
 
Historia y clasificación celular
Giuliana Tinoco
 
Metadata and the Power of Pattern-Finding
DATAVERSITY
 
Ad

Similar to Using type script to build better apps (20)

PDF
TypeScript: coding JavaScript without the pain
Sander Mak (@Sander_Mak)
 
PDF
Reasons to Use Typescript for Your Next Project Over Javascript.pdf
MobMaxime
 
PDF
TypeScipt - Get Started
Krishnanand Sivaraj
 
PDF
TypeScript introduction to scalable javascript application
Andrea Paciolla
 
PDF
Introduction to TypeScript
NexThoughts Technologies
 
PDF
An Introduction to TypeScript: Definition, History, and Key Features
Michael Coplin
 
PDF
What is TypeScript? It's Definition, History And Features
HarryParker32
 
PPTX
Type script
Mallikarjuna G D
 
PDF
4Developers: Tomasz Ducin- JavaScript + Java = TypeScript
PROIDEA
 
PPTX
Getting started with typescript
C...L, NESPRESSO, WAFAASSURANCE, SOFRECOM ORANGE
 
PDF
Type script
srinivaskapa1
 
PPTX
TypeScript Overview
Aniruddha Chakrabarti
 
PPTX
Complete Notes on Angular 2 and TypeScript
EPAM Systems
 
PDF
Typescript for the programmers who like javascript
Andrei Sebastian Cîmpean
 
PPTX
The advantage of developing with TypeScript
Corley S.r.l.
 
PPTX
AngularConf2015
Alessandro Giorgetti
 
PDF
Migrating Web SDK from JS to TS
Grigory Petrov
 
PPTX
Typescript: Beginner to Advanced
Talentica Software
 
PPTX
Rits Brown Bag - TypeScript
Right IT Services
 
PPTX
Introducing type script
Remo Jansen
 
TypeScript: coding JavaScript without the pain
Sander Mak (@Sander_Mak)
 
Reasons to Use Typescript for Your Next Project Over Javascript.pdf
MobMaxime
 
TypeScipt - Get Started
Krishnanand Sivaraj
 
TypeScript introduction to scalable javascript application
Andrea Paciolla
 
Introduction to TypeScript
NexThoughts Technologies
 
An Introduction to TypeScript: Definition, History, and Key Features
Michael Coplin
 
What is TypeScript? It's Definition, History And Features
HarryParker32
 
Type script
Mallikarjuna G D
 
4Developers: Tomasz Ducin- JavaScript + Java = TypeScript
PROIDEA
 
Getting started with typescript
C...L, NESPRESSO, WAFAASSURANCE, SOFRECOM ORANGE
 
Type script
srinivaskapa1
 
TypeScript Overview
Aniruddha Chakrabarti
 
Complete Notes on Angular 2 and TypeScript
EPAM Systems
 
Typescript for the programmers who like javascript
Andrei Sebastian Cîmpean
 
The advantage of developing with TypeScript
Corley S.r.l.
 
AngularConf2015
Alessandro Giorgetti
 
Migrating Web SDK from JS to TS
Grigory Petrov
 
Typescript: Beginner to Advanced
Talentica Software
 
Rits Brown Bag - TypeScript
Right IT Services
 
Introducing type script
Remo Jansen
 

More from ColdFusionConference (20)

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

Recently uploaded (20)

PPTX
Smart Infrastructure and Automation through IoT Sensors
Rejig Digital
 
PDF
Oracle AI Vector Search- Getting Started and what's new in 2025- AIOUG Yatra ...
Sandesh Rao
 
PPT
L2 Rules of Netiquette in Empowerment technology
Archibal2
 
PDF
Automating ArcGIS Content Discovery with FME: A Real World Use Case
Safe Software
 
PDF
This slide provides an overview Technology
mineshkharadi333
 
PDF
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
PPTX
The-Ethical-Hackers-Imperative-Safeguarding-the-Digital-Frontier.pptx
sujalchauhan1305
 
PDF
Unlocking the Future- AI Agents Meet Oracle Database 23ai - AIOUG Yatra 2025.pdf
Sandesh Rao
 
PDF
Orbitly Pitch Deck|A Mission-Driven Platform for Side Project Collaboration (...
zz41354899
 
PPTX
ChatGPT's Deck on The Enduring Legacy of Fax Machines
Greg Swan
 
PDF
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
PDF
Structs to JSON: How Go Powers REST APIs
Emily Achieng
 
PDF
Why Your AI & Cybersecurity Hiring Still Misses the Mark in 2025
Virtual Employee Pvt. Ltd.
 
PDF
How-Cloud-Computing-Impacts-Businesses-in-2025-and-Beyond.pdf
Artjoker Software Development Company
 
PDF
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
PDF
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
PDF
Software Development Methodologies in 2025
KodekX
 
PDF
Chapter 1 Introduction to CV and IP Lecture Note.pdf
Getnet Tigabie Askale -(GM)
 
PDF
Tea4chat - another LLM Project by Kerem Atam
a0m0rajab1
 
PDF
Best ERP System for Manufacturing in India | Elite Mindz
Elite Mindz
 
Smart Infrastructure and Automation through IoT Sensors
Rejig Digital
 
Oracle AI Vector Search- Getting Started and what's new in 2025- AIOUG Yatra ...
Sandesh Rao
 
L2 Rules of Netiquette in Empowerment technology
Archibal2
 
Automating ArcGIS Content Discovery with FME: A Real World Use Case
Safe Software
 
This slide provides an overview Technology
mineshkharadi333
 
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
The-Ethical-Hackers-Imperative-Safeguarding-the-Digital-Frontier.pptx
sujalchauhan1305
 
Unlocking the Future- AI Agents Meet Oracle Database 23ai - AIOUG Yatra 2025.pdf
Sandesh Rao
 
Orbitly Pitch Deck|A Mission-Driven Platform for Side Project Collaboration (...
zz41354899
 
ChatGPT's Deck on The Enduring Legacy of Fax Machines
Greg Swan
 
Data_Analytics_vs_Data_Science_vs_BI_by_CA_Suvidha_Chaplot.pdf
CA Suvidha Chaplot
 
Structs to JSON: How Go Powers REST APIs
Emily Achieng
 
Why Your AI & Cybersecurity Hiring Still Misses the Mark in 2025
Virtual Employee Pvt. Ltd.
 
How-Cloud-Computing-Impacts-Businesses-in-2025-and-Beyond.pdf
Artjoker Software Development Company
 
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
Security features in Dell, HP, and Lenovo PC systems: A research-based compar...
Principled Technologies
 
Software Development Methodologies in 2025
KodekX
 
Chapter 1 Introduction to CV and IP Lecture Note.pdf
Getnet Tigabie Askale -(GM)
 
Tea4chat - another LLM Project by Kerem Atam
a0m0rajab1
 
Best ERP System for Manufacturing in India | Elite Mindz
Elite Mindz
 

Using type script to build better apps