SlideShare a Scribd company logo
Typescript Development
with
ServiceWorker and ES6 Modules
: @brn ( a.k.a )
: iOS 
: Cyberagent RightSegment AI Messenger
: http://abcdef.gets.b6n.ch/
Twitter: https://twitter.com/brn227
GitHub: https://github.com/brn
What	is	ServiceWorker?
ServiceWorker Web
http javascript


https://developers.google.com/web/fundamentals/getting-started/
primers/service-workers?hl=ja
Intercept	http	request
ServiceWorker http 
ES6 Modules Typescript
ES6	Modules

babel 
Safari Chrome Canaray 

ES6 Modules 
Typescript
Typescript	Compiler

CompilerHost 
ts.transpileModule 1 

https://github.com/Microsoft/TypeScript/wiki/Using-the-Compiler-API#a-simple-transform-function
Strategy


•  ServiceWorker install skipWating 
•  ServiceWorker activate claim 
•  navigator.serviceWorker.register Promise active

•  active typescript script type="module" 
•  ServiceWorker fetch
tsconfig.json
tsconfig.json 

•  postMessage tsconfig 
•  tsconfig ServiceWorker postMessage 
•  typescript
Strategy
ServiceWorker install 
waiting active 
fetch 
install	 active
Strategy

self.skipWaiting() activate claim()
controllerchange
active postMesseage
tsconfig.json
install	 active	
skipWaiting
controllerchange	
Main
postMessage
Strategy
register()
controllerchange
postMessage(load	tsconfig)
postMessage(load	succeeded)
load	typescript	via	script	tag
...
ServiceWorker	 Main	
install	
active	
skipWaiting()
claim()
wait fetch event	
load	typescript	via	ES6	import
transpileModule
transpileModule
Transpiled	code
Demo

https://brn.github.io/swts/
Problem
ES6 Modules Module 
npm Module 

Module
GitHub
npm module 
https://github.com/brn/swts.git
Summary
ServiceWorker babel typescript 
ES6 Modules 
commonjs 
commonjs => ES6 modules amd Systemjs 
ES6 Modules tranpile
Summary

More Related Content

PPTX
Spring Northwest Usergroup Grails Presentation
PDF
Get Hip with Java Hipster - JavaOne 2017
PDF
Sergey Puzankov "How to see a bug the size of 1px"
PDF
JHipster, modern web application development made easy
PDF
Angular is one fire(base)! - Shmuela Jacobs
PPTX
The State of the Developer Ecosystem - .NET Conf Barcelona 2018
PDF
What's New in JHipsterLand - DevNexus 2017
PDF
Using JHipster 4 for generating Angular/Spring Boot apps
Spring Northwest Usergroup Grails Presentation
Get Hip with Java Hipster - JavaOne 2017
Sergey Puzankov "How to see a bug the size of 1px"
JHipster, modern web application development made easy
Angular is one fire(base)! - Shmuela Jacobs
The State of the Developer Ecosystem - .NET Conf Barcelona 2018
What's New in JHipsterLand - DevNexus 2017
Using JHipster 4 for generating Angular/Spring Boot apps

What's hot (20)

PDF
Front Ends for Back End Developers - Spring I/O 2017
PDF
Using JHipster for generating Angular/Spring Boot apps
PDF
Why you should add React to your Rails application now!
PDF
React, GraphQL и Relay - вполне себе нормальный компонентный подход (nodkz)
PPT
sbt 0.10 for beginners?
PPTX
Grails Spring Boot
PDF
Spring IO '15 - Developing microservices, Spring Boot or Grails?
PDF
Full Stack Reactive with React and Spring WebFlux - SpringOne 2018
PDF
No more waiting for API - Android Stub Server
PPT
Lifthub (rpscala #31)
PDF
Afupday lille-2020
PPTX
How we built a job board in one week with JHipster
PPTX
Java and services code lab spring boot and spring data using mongo db
ODP
Eclipse Buildship JUG Hamburg
PPTX
Continuous deployment of Rails apps on AWS OpsWorks
PDF
Wuff: Building Eclipse Applications and Plugins with Gradle
PDF
Angular vs React Smackdown - Devoxx BE 2017
PDF
Front End Development for Back End Developers - vJUG24 2017
PDF
Tales of an open source library
PDF
"The Story of Declarative React at Grammarly: From two-way data binding with ...
Front Ends for Back End Developers - Spring I/O 2017
Using JHipster for generating Angular/Spring Boot apps
Why you should add React to your Rails application now!
React, GraphQL и Relay - вполне себе нормальный компонентный подход (nodkz)
sbt 0.10 for beginners?
Grails Spring Boot
Spring IO '15 - Developing microservices, Spring Boot or Grails?
Full Stack Reactive with React and Spring WebFlux - SpringOne 2018
No more waiting for API - Android Stub Server
Lifthub (rpscala #31)
Afupday lille-2020
How we built a job board in one week with JHipster
Java and services code lab spring boot and spring data using mongo db
Eclipse Buildship JUG Hamburg
Continuous deployment of Rails apps on AWS OpsWorks
Wuff: Building Eclipse Applications and Plugins with Gradle
Angular vs React Smackdown - Devoxx BE 2017
Front End Development for Back End Developers - vJUG24 2017
Tales of an open source library
"The Story of Declarative React at Grammarly: From two-way data binding with ...
Ad

More from Taketoshi 青野健利 (10)

PDF
javascriptのデータ構造の話
PDF
V8 javascript engine for フロントエンドデベロッパー
PDF
非同期javascriptの過去と未来
PDF
仮想DOMの実装とパフォーマンス
PDF
JavascriptのGC入門
PDF
V8 Iginition Interpreter
PDF
GraphQL with React
PDF
Jspmとtypescriptで開発する
PPTX
PDF
WebWorker and Atomics
javascriptのデータ構造の話
V8 javascript engine for フロントエンドデベロッパー
非同期javascriptの過去と未来
仮想DOMの実装とパフォーマンス
JavascriptのGC入門
V8 Iginition Interpreter
GraphQL with React
Jspmとtypescriptで開発する
WebWorker and Atomics
Ad

Recently uploaded (20)

PDF
Mohammad Mahdi Farshadian CV - Prospective PhD Student 2026
PPTX
CYBER-CRIMES AND SECURITY A guide to understanding
PDF
Structs to JSON How Go Powers REST APIs.pdf
PPTX
Strings in CPP - Strings in C++ are sequences of characters used to store and...
DOCX
573137875-Attendance-Management-System-original
PDF
Well-logging-methods_new................
PPTX
KTU 2019 -S7-MCN 401 MODULE 2-VINAY.pptx
PDF
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
PDF
Mitigating Risks through Effective Management for Enhancing Organizational Pe...
PPTX
Engineering Ethics, Safety and Environment [Autosaved] (1).pptx
PPTX
UNIT-1 - COAL BASED THERMAL POWER PLANTS
PPTX
UNIT 4 Total Quality Management .pptx
PDF
keyrequirementskkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk
PPTX
Construction Project Organization Group 2.pptx
PDF
July 2025 - Top 10 Read Articles in International Journal of Software Enginee...
PDF
Embodied AI: Ushering in the Next Era of Intelligent Systems
PPTX
MET 305 2019 SCHEME MODULE 2 COMPLETE.pptx
PDF
Arduino robotics embedded978-1-4302-3184-4.pdf
PPTX
Welding lecture in detail for understanding
DOCX
ASol_English-Language-Literature-Set-1-27-02-2023-converted.docx
Mohammad Mahdi Farshadian CV - Prospective PhD Student 2026
CYBER-CRIMES AND SECURITY A guide to understanding
Structs to JSON How Go Powers REST APIs.pdf
Strings in CPP - Strings in C++ are sequences of characters used to store and...
573137875-Attendance-Management-System-original
Well-logging-methods_new................
KTU 2019 -S7-MCN 401 MODULE 2-VINAY.pptx
BMEC211 - INTRODUCTION TO MECHATRONICS-1.pdf
Mitigating Risks through Effective Management for Enhancing Organizational Pe...
Engineering Ethics, Safety and Environment [Autosaved] (1).pptx
UNIT-1 - COAL BASED THERMAL POWER PLANTS
UNIT 4 Total Quality Management .pptx
keyrequirementskkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk
Construction Project Organization Group 2.pptx
July 2025 - Top 10 Read Articles in International Journal of Software Enginee...
Embodied AI: Ushering in the Next Era of Intelligent Systems
MET 305 2019 SCHEME MODULE 2 COMPLETE.pptx
Arduino robotics embedded978-1-4302-3184-4.pdf
Welding lecture in detail for understanding
ASol_English-Language-Literature-Set-1-27-02-2023-converted.docx

ServiceWorkerとES6 Modules時代のTypescript開発考察