SlideShare a Scribd company logo
1 of 11
TypeScriptifying
the “Flagrate” JavaScript UI Library
14th June 2014 #buildinsider – Yuki KAN / CEO at Webnium Inc.
@kanreisa
What is the Flagrate ?
@kanreisa 2
What is the Flagrate ?
• DOM スクリプティング / UI ライブラリ (クライアントJavaScript)
• IE / Chrome / Firefox / Safari / Opera / Windows Store App に対応
• スタンドアローン: jQuery, Prototype 等に全く依存しない
• グローバル汚染しない
• DOM構築パフォーマンスが最も高速
• jQuery UI, Sencha, Bootstrap系 と比較
@kanreisa 3
Performance DEMO
Flagrate.Grid / Flagrate.Form
TypeScriptifying
Flagrate
TypeScriptifying
• Windows / VisualStudio に依存しないビルドシステムが必要
• streaming build system “gulp.js” を使用 → http://gulpjs.com/
実際のスクリプトはこちら
https://github.com/webnium/flagrate/blob/feature/typescript/gulpfile.js
TypeScriptifying
• 非常に巨大なため、クラスごとにファイルを分けたい
• でも最終的には1つのJSとしてまとめたい (require/amd使わない)
• “gulp.js” のプラグイン “gulp-include” で実現
実際のスクリプトはこちら
https://github.com/webnium/flagrate/blob/feature/typescript/src/flagrate.js
https://github.com/webnium/flagrate/blob/feature/typescript/src/flagrate.ts
TypeScriptifying
• “gulp.js” で簡単にスクリプト保存時自動ビルド等も実現
TypeScriptifying
• あとは地道に
ジェネリクスいいですよね
TypeScripting DEMO
Using flagrate.d.ts
あじゃじゃしたー
Thank you for watching

More Related Content

Viewers also liked

Business Leader Development Program
Business Leader Development ProgramBusiness Leader Development Program
Business Leader Development ProgramCindy McAsey
 
Dealing with controversial issues
Dealing with controversial issuesDealing with controversial issues
Dealing with controversial issuesJillian May Peralta
 
2016 April Announcements
2016 April Announcements2016 April Announcements
2016 April AnnouncementsWayne Irwin
 
Infoz corporate presntation
Infoz corporate presntationInfoz corporate presntation
Infoz corporate presntationMahesh Chimankar
 
Randi Zuckerberg at Landlord WEBCON 2014
Randi Zuckerberg at Landlord WEBCON 2014Randi Zuckerberg at Landlord WEBCON 2014
Randi Zuckerberg at Landlord WEBCON 2014LandlordWebCon
 
клёпа литературный урок цнс 2015 расширенная
клёпа литературный урок цнс 2015 расширеннаяклёпа литературный урок цнс 2015 расширенная
клёпа литературный урок цнс 2015 расширеннаяklepa.ru
 
Major trends in_e_commerce_2011
Major trends in_e_commerce_2011Major trends in_e_commerce_2011
Major trends in_e_commerce_2011Majd Abi Ali
 
Task 6 – teaser trailers and the film
Task 6 – teaser trailers and the filmTask 6 – teaser trailers and the film
Task 6 – teaser trailers and the filmSammo_644
 
Customer experience in 2014 - Take 2
Customer experience in 2014 - Take 2Customer experience in 2014 - Take 2
Customer experience in 2014 - Take 2Centrecom
 

Viewers also liked (12)

Business Leader Development Program
Business Leader Development ProgramBusiness Leader Development Program
Business Leader Development Program
 
Dealing with controversial issues
Dealing with controversial issuesDealing with controversial issues
Dealing with controversial issues
 
2016 April Announcements
2016 April Announcements2016 April Announcements
2016 April Announcements
 
Infoz corporate presntation
Infoz corporate presntationInfoz corporate presntation
Infoz corporate presntation
 
Randi Zuckerberg at Landlord WEBCON 2014
Randi Zuckerberg at Landlord WEBCON 2014Randi Zuckerberg at Landlord WEBCON 2014
Randi Zuckerberg at Landlord WEBCON 2014
 
клёпа литературный урок цнс 2015 расширенная
клёпа литературный урок цнс 2015 расширеннаяклёпа литературный урок цнс 2015 расширенная
клёпа литературный урок цнс 2015 расширенная
 
Major trends in_e_commerce_2011
Major trends in_e_commerce_2011Major trends in_e_commerce_2011
Major trends in_e_commerce_2011
 
Vih
VihVih
Vih
 
Task 6 – teaser trailers and the film
Task 6 – teaser trailers and the filmTask 6 – teaser trailers and the film
Task 6 – teaser trailers and the film
 
Customer experience in 2014 - Take 2
Customer experience in 2014 - Take 2Customer experience in 2014 - Take 2
Customer experience in 2014 - Take 2
 
Back to church 2012
Back to church 2012Back to church 2012
Back to church 2012
 
Strategic management
Strategic managementStrategic management
Strategic management
 

Typescriptifying the "Flagrate" JavaScript UI Library (LT)