SlideShare a Scribd company logo
1 of 35
Download to read offline
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved.
ทำไม App ช้า ๆ แก้หน่อยสิ !!
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 2
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 3
Tuning perfomance
Investigate
Fix
Measure
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 4
Code splitting
Preload strategy
Performance budget
Differential loading
Initial load time
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 5
Building
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 6
Building
Development build
$ng build
Production build
$ng build --prod
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 7
Dev vs. Prod build
Dev Prod
Environment environment.ts environment.prod.ts
Cache-busting Only image ref from css All build files
Source maps Generated Not generated
Extracted CSS Global CSS to .js To .css
Uglification No Yes
Bundling Yes Yes
AOT No Yes
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 8
Prod build :: Smaller & Faster
Dev Prod
Environment environment.ts environment.prod.ts
Cache-busting Only image ref from css All build files
Source maps Generated Not generated
Extracted CSS Global CSS to .js To .css
Uglification No Yes
Bundling Yes Yes
AOT No Yes
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 9
Building
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 10
Building with source maps
$npm install source-map-explorer --save-dev
$ng build --prod --source-map
https://angular.io/guide/deployment
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 11
Analyse sources
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 12
Analyse sources
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 13
Tips source maps
angular.json
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 14
Sentry
https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 15
Sentry without source maps
https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 16
ขอสวย ๆ กว่านี้หน่อยสิ
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 17
Sentry
https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 18
เรื่องฮา ๆ แต่เจ็บ
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 19
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 20
Listing
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 21
Using trackBy in ngFor
Ensure only the list element that has changed
will be rendered (Not all)
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 22
Using trackBy in ngFor
Ensure only the list element that has changed
will be rendered (Not all)
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 23
Listing
Using ngFor directive
https://angular.io/api/common/NgForOf#ngForTrackBy
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 24
Common solution from Doc
Using ngFor + trackBy
https://angular.io/api/common/NgForOf#ngForTrackBy
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 25
ทำไมไม่ช่วยกูวะ !!
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 26
เร็วขึ้นนะ
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 27
แต่ไม่ต้องการให้
template render ใหม่ !!
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 28
ทำไมดีหว่า ?
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 29
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 30
Hard code ไปเลย แจ่ม !!
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 31
ไม่น่าเชื่อเร็วขึ้น 30-50% เป็นสุข
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 32
ได้แรงบัลดาลใจ
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 33
ไปค้นหา google ต่อ
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 34
กลับบ้านไปเขียน code
Meetup
© 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 35
กลับบ้านไปเขียน code
เขียน test ด้วยนะ

More Related Content

What's hot

vTalk#1 Microservices with Spring Boot
vTalk#1 Microservices with Spring BootvTalk#1 Microservices with Spring Boot
vTalk#1 Microservices with Spring BootSomkiat Puisungnoen
 
Microservices and APIs
Microservices and APIsMicroservices and APIs
Microservices and APIsPuneet Sachdev
 
CWIN17 telford api management, practical implementation experience - david ru...
CWIN17 telford api management, practical implementation experience - david ru...CWIN17 telford api management, practical implementation experience - david ru...
CWIN17 telford api management, practical implementation experience - david ru...Capgemini
 
Intro to service mesh & Istio
Intro to service mesh & IstioIntro to service mesh & Istio
Intro to service mesh & IstioRinor Maloku
 
Cover Your Apps While Still Using npm
Cover Your Apps While Still Using npmCover Your Apps While Still Using npm
Cover Your Apps While Still Using npmTierney Cyren
 
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0Mirko Kleiner
 
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...Sogeti Nederland B.V.
 
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation Factory
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation FactoryNeste: How to Build Business Case, Ramp-up and Run SAP Test Automation Factory
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation FactorySogeti Nederland B.V.
 
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile Procurement
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile ProcurementAgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile Procurement
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile ProcurementMirko Kleiner
 
Is React The Best Thing Since Sliced Bread?
Is React The Best Thing Since Sliced Bread?Is React The Best Thing Since Sliced Bread?
Is React The Best Thing Since Sliced Bread?Synerzip
 
Virgin Media's WebEx Social to Jive Content Migration Story
Virgin Media's WebEx Social to Jive Content Migration StoryVirgin Media's WebEx Social to Jive Content Migration Story
Virgin Media's WebEx Social to Jive Content Migration StorySei Mani
 
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...Sogeti Nederland B.V.
 

What's hot (15)

Wordpress for Newbie
Wordpress for NewbieWordpress for Newbie
Wordpress for Newbie
 
Sck Agile in Real World
Sck Agile in Real WorldSck Agile in Real World
Sck Agile in Real World
 
vTalk#1 Microservices with Spring Boot
vTalk#1 Microservices with Spring BootvTalk#1 Microservices with Spring Boot
vTalk#1 Microservices with Spring Boot
 
Your Flight is Boarding Now!
Your Flight is Boarding Now!Your Flight is Boarding Now!
Your Flight is Boarding Now!
 
Microservices and APIs
Microservices and APIsMicroservices and APIs
Microservices and APIs
 
CWIN17 telford api management, practical implementation experience - david ru...
CWIN17 telford api management, practical implementation experience - david ru...CWIN17 telford api management, practical implementation experience - david ru...
CWIN17 telford api management, practical implementation experience - david ru...
 
Intro to service mesh & Istio
Intro to service mesh & IstioIntro to service mesh & Istio
Intro to service mesh & Istio
 
Cover Your Apps While Still Using npm
Cover Your Apps While Still Using npmCover Your Apps While Still Using npm
Cover Your Apps While Still Using npm
 
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0
Cips Meetup Auckland-Mirko-Kleiner-lean-agile-procurement-201904-1.0
 
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...
Quality Assurance in fast paced DevOps projects using automation - Patrick Ve...
 
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation Factory
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation FactoryNeste: How to Build Business Case, Ramp-up and Run SAP Test Automation Factory
Neste: How to Build Business Case, Ramp-up and Run SAP Test Automation Factory
 
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile Procurement
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile ProcurementAgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile Procurement
AgileSerbia 2019-Closing Keynote by Mirko-Kleiner about Lean-Agile Procurement
 
Is React The Best Thing Since Sliced Bread?
Is React The Best Thing Since Sliced Bread?Is React The Best Thing Since Sliced Bread?
Is React The Best Thing Since Sliced Bread?
 
Virgin Media's WebEx Social to Jive Content Migration Story
Virgin Media's WebEx Social to Jive Content Migration StoryVirgin Media's WebEx Social to Jive Content Migration Story
Virgin Media's WebEx Social to Jive Content Migration Story
 
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...
Agile Quality Improvement 7: common challenges and good practices - Wouter Ru...
 

Similar to Angular :: basic tuning performance

CWIN17 telford application integration and ap is - lisa eckersley
CWIN17 telford   application integration and ap is - lisa eckersleyCWIN17 telford   application integration and ap is - lisa eckersley
CWIN17 telford application integration and ap is - lisa eckersleyCapgemini
 
Javascript for Enterprise Application
Javascript for Enterprise ApplicationJavascript for Enterprise Application
Javascript for Enterprise ApplicationSoham Dasgupta
 
Automatic for the People
Automatic for the PeopleAutomatic for the People
Automatic for the PeopleAllon Mureinik
 
Modernizing Service Management Processes with Self-Service Access
Modernizing Service Management Processes with Self-Service AccessModernizing Service Management Processes with Self-Service Access
Modernizing Service Management Processes with Self-Service AccessITSM Academy, Inc.
 
Sitecore and the Future of Web Development
Sitecore and the Future of Web DevelopmentSitecore and the Future of Web Development
Sitecore and the Future of Web DevelopmentAdrian IORGU
 
【Primer】WebApp release in 3 hours! Programming from scratch Rails course
【Primer】WebApp release in 3 hours! Programming from scratch Rails course【Primer】WebApp release in 3 hours! Programming from scratch Rails course
【Primer】WebApp release in 3 hours! Programming from scratch Rails courseDIVE INTO CODE Corp.
 
Magento Cloud - Introduction
Magento Cloud - IntroductionMagento Cloud - Introduction
Magento Cloud - IntroductionOleg Posyniak
 
Elevate Your Application Security Program with Burp Suite and ThreadFix
Elevate Your Application Security Program with Burp Suite and ThreadFix Elevate Your Application Security Program with Burp Suite and ThreadFix
Elevate Your Application Security Program with Burp Suite and ThreadFix Denim Group
 
AgileDays 2019 Moscow Procurement on Disruption
AgileDays 2019 Moscow Procurement on DisruptionAgileDays 2019 Moscow Procurement on Disruption
AgileDays 2019 Moscow Procurement on DisruptionMirko Kleiner
 
Getting Started with AWS for Develoeprs
Getting Started with AWS for DeveloeprsGetting Started with AWS for Develoeprs
Getting Started with AWS for DeveloeprsAmazon Web Services
 
Digital Transformation. Examples from Automotive Industry
Digital Transformation. Examples from Automotive IndustryDigital Transformation. Examples from Automotive Industry
Digital Transformation. Examples from Automotive IndustryBoost40
 
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"Dakiry
 
Testing Microsoft Dynamics NAV with Rapise
Testing Microsoft Dynamics NAV with RapiseTesting Microsoft Dynamics NAV with Rapise
Testing Microsoft Dynamics NAV with RapiseAdam Sandman
 
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017Kendo UI workshop introduction - PUG Baltic Annual Conference 2017
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017Alen Leit
 
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing Cloud
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing CloudIMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing Cloud
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing CloudAdobeMarketingCloud
 
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018Amazon Web Services
 
DevOps in a Nutshell
DevOps in a NutshellDevOps in a Nutshell
DevOps in a NutshellArne Roßmann
 

Similar to Angular :: basic tuning performance (20)

SCK Firestore at CNX
SCK Firestore at CNXSCK Firestore at CNX
SCK Firestore at CNX
 
Clean you code
Clean you codeClean you code
Clean you code
 
CWIN17 telford application integration and ap is - lisa eckersley
CWIN17 telford   application integration and ap is - lisa eckersleyCWIN17 telford   application integration and ap is - lisa eckersley
CWIN17 telford application integration and ap is - lisa eckersley
 
Javascript for Enterprise Application
Javascript for Enterprise ApplicationJavascript for Enterprise Application
Javascript for Enterprise Application
 
Automatic for the People
Automatic for the PeopleAutomatic for the People
Automatic for the People
 
Modernizing Service Management Processes with Self-Service Access
Modernizing Service Management Processes with Self-Service AccessModernizing Service Management Processes with Self-Service Access
Modernizing Service Management Processes with Self-Service Access
 
Sitecore and the Future of Web Development
Sitecore and the Future of Web DevelopmentSitecore and the Future of Web Development
Sitecore and the Future of Web Development
 
【Primer】WebApp release in 3 hours! Programming from scratch Rails course
【Primer】WebApp release in 3 hours! Programming from scratch Rails course【Primer】WebApp release in 3 hours! Programming from scratch Rails course
【Primer】WebApp release in 3 hours! Programming from scratch Rails course
 
Magento Cloud - Introduction
Magento Cloud - IntroductionMagento Cloud - Introduction
Magento Cloud - Introduction
 
Cloud Foundry Summit 2017
Cloud Foundry Summit 2017Cloud Foundry Summit 2017
Cloud Foundry Summit 2017
 
Elevate Your Application Security Program with Burp Suite and ThreadFix
Elevate Your Application Security Program with Burp Suite and ThreadFix Elevate Your Application Security Program with Burp Suite and ThreadFix
Elevate Your Application Security Program with Burp Suite and ThreadFix
 
AgileDays 2019 Moscow Procurement on Disruption
AgileDays 2019 Moscow Procurement on DisruptionAgileDays 2019 Moscow Procurement on Disruption
AgileDays 2019 Moscow Procurement on Disruption
 
Getting Started with AWS for Develoeprs
Getting Started with AWS for DeveloeprsGetting Started with AWS for Develoeprs
Getting Started with AWS for Develoeprs
 
Digital Transformation. Examples from Automotive Industry
Digital Transformation. Examples from Automotive IndustryDigital Transformation. Examples from Automotive Industry
Digital Transformation. Examples from Automotive Industry
 
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"
ROMA NOVIKOV, BAQ, "Prometheus + grafana based monitoring"
 
Testing Microsoft Dynamics NAV with Rapise
Testing Microsoft Dynamics NAV with RapiseTesting Microsoft Dynamics NAV with Rapise
Testing Microsoft Dynamics NAV with Rapise
 
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017Kendo UI workshop introduction - PUG Baltic Annual Conference 2017
Kendo UI workshop introduction - PUG Baltic Annual Conference 2017
 
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing Cloud
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing CloudIMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing Cloud
IMMERSE'16 Intro to Adobe Experience Manager & Adobe Marketing Cloud
 
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018
Getting Started with AWS Developers: AWS Developer Workshop - Web Summit 2018
 
DevOps in a Nutshell
DevOps in a NutshellDevOps in a Nutshell
DevOps in a Nutshell
 

More from Somkiat Puisungnoen (17)

devops
devops devops
devops
 
Manage data of service
Manage data of serviceManage data of service
Manage data of service
 
Cloud Native App
Cloud Native AppCloud Native App
Cloud Native App
 
Unhappiness Developer
Unhappiness DeveloperUnhappiness Developer
Unhappiness Developer
 
The Beauty of BAD code
The Beauty of  BAD codeThe Beauty of  BAD code
The Beauty of BAD code
 
React in the right way
React in the right wayReact in the right way
React in the right way
 
Rise of Container (RoC)
Rise of Container (RoC)Rise of Container (RoC)
Rise of Container (RoC)
 
SCK :: Scrum is NOT Enough
SCK :: Scrum is NOT EnoughSCK :: Scrum is NOT Enough
SCK :: Scrum is NOT Enough
 
Software Development Trends 2017 at IMC
Software Development Trends 2017 at IMCSoftware Development Trends 2017 at IMC
Software Development Trends 2017 at IMC
 
Design pattern with Java 8
Design pattern with Java 8Design pattern with Java 8
Design pattern with Java 8
 
Meetup :: Update Elastic Stack 5.0
Meetup :: Update Elastic Stack 5.0Meetup :: Update Elastic Stack 5.0
Meetup :: Update Elastic Stack 5.0
 
Git as NoSQL
Git as NoSQLGit as NoSQL
Git as NoSQL
 
DevOps 101
DevOps 101DevOps 101
DevOps 101
 
Sck Mobile Application Security
Sck Mobile Application SecuritySck Mobile Application Security
Sck Mobile Application Security
 
Automation test for Android
Automation test for AndroidAutomation test for Android
Automation test for Android
 
Secure Test-Driven Development
Secure Test-Driven DevelopmentSecure Test-Driven Development
Secure Test-Driven Development
 
Working with branch
Working with branchWorking with branch
Working with branch
 

Recently uploaded

Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Wonjun Hwang
 
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Mark Simos
 
WordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your BrandWordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your Brandgvaughan
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticscarlostorres15106
 
Unraveling Multimodality with Large Language Models.pdf
Unraveling Multimodality with Large Language Models.pdfUnraveling Multimodality with Large Language Models.pdf
Unraveling Multimodality with Large Language Models.pdfAlex Barbosa Coqueiro
 
Gen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfGen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfAddepto
 
My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024The Digital Insurer
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsMemoori
 
Build your next Gen AI Breakthrough - April 2024
Build your next Gen AI Breakthrough - April 2024Build your next Gen AI Breakthrough - April 2024
Build your next Gen AI Breakthrough - April 2024Neo4j
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksSoftradix Technologies
 
costume and set research powerpoint presentation
costume and set research powerpoint presentationcostume and set research powerpoint presentation
costume and set research powerpoint presentationphoebematthew05
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024BookNet Canada
 
Dev Dives: Streamline document processing with UiPath Studio Web
Dev Dives: Streamline document processing with UiPath Studio WebDev Dives: Streamline document processing with UiPath Studio Web
Dev Dives: Streamline document processing with UiPath Studio WebUiPathCommunity
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):comworks
 
SIP trunking in Janus @ Kamailio World 2024
SIP trunking in Janus @ Kamailio World 2024SIP trunking in Janus @ Kamailio World 2024
SIP trunking in Janus @ Kamailio World 2024Lorenzo Miniero
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Enterprise Knowledge
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Scott Keck-Warren
 

Recently uploaded (20)

Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
 
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
 
WordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your BrandWordPress Websites for Engineers: Elevate Your Brand
WordPress Websites for Engineers: Elevate Your Brand
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
 
DMCC Future of Trade Web3 - Special Edition
DMCC Future of Trade Web3 - Special EditionDMCC Future of Trade Web3 - Special Edition
DMCC Future of Trade Web3 - Special Edition
 
Unraveling Multimodality with Large Language Models.pdf
Unraveling Multimodality with Large Language Models.pdfUnraveling Multimodality with Large Language Models.pdf
Unraveling Multimodality with Large Language Models.pdf
 
Hot Sexy call girls in Panjabi Bagh 🔝 9953056974 🔝 Delhi escort Service
Hot Sexy call girls in Panjabi Bagh 🔝 9953056974 🔝 Delhi escort ServiceHot Sexy call girls in Panjabi Bagh 🔝 9953056974 🔝 Delhi escort Service
Hot Sexy call girls in Panjabi Bagh 🔝 9953056974 🔝 Delhi escort Service
 
Gen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfGen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdf
 
My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024My INSURER PTE LTD - Insurtech Innovation Award 2024
My INSURER PTE LTD - Insurtech Innovation Award 2024
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial Buildings
 
Build your next Gen AI Breakthrough - April 2024
Build your next Gen AI Breakthrough - April 2024Build your next Gen AI Breakthrough - April 2024
Build your next Gen AI Breakthrough - April 2024
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other Frameworks
 
costume and set research powerpoint presentation
costume and set research powerpoint presentationcostume and set research powerpoint presentation
costume and set research powerpoint presentation
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC BiblioShare - Tech Forum 2024
 
Dev Dives: Streamline document processing with UiPath Studio Web
Dev Dives: Streamline document processing with UiPath Studio WebDev Dives: Streamline document processing with UiPath Studio Web
Dev Dives: Streamline document processing with UiPath Studio Web
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):
 
SIP trunking in Janus @ Kamailio World 2024
SIP trunking in Janus @ Kamailio World 2024SIP trunking in Janus @ Kamailio World 2024
SIP trunking in Janus @ Kamailio World 2024
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024
 

Angular :: basic tuning performance

  • 1. © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. ทำไม App ช้า ๆ แก้หน่อยสิ !!
  • 2. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 2
  • 3. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 3 Tuning perfomance Investigate Fix Measure
  • 4. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 4 Code splitting Preload strategy Performance budget Differential loading Initial load time
  • 5. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 5 Building
  • 6. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 6 Building Development build $ng build Production build $ng build --prod
  • 7. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 7 Dev vs. Prod build Dev Prod Environment environment.ts environment.prod.ts Cache-busting Only image ref from css All build files Source maps Generated Not generated Extracted CSS Global CSS to .js To .css Uglification No Yes Bundling Yes Yes AOT No Yes
  • 8. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 8 Prod build :: Smaller & Faster Dev Prod Environment environment.ts environment.prod.ts Cache-busting Only image ref from css All build files Source maps Generated Not generated Extracted CSS Global CSS to .js To .css Uglification No Yes Bundling Yes Yes AOT No Yes
  • 9. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 9 Building
  • 10. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 10 Building with source maps $npm install source-map-explorer --save-dev $ng build --prod --source-map https://angular.io/guide/deployment
  • 11. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 11 Analyse sources
  • 12. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 12 Analyse sources
  • 13. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 13 Tips source maps angular.json
  • 14. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 14 Sentry https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
  • 15. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 15 Sentry without source maps https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
  • 16. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 16 ขอสวย ๆ กว่านี้หน่อยสิ
  • 17. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 17 Sentry https://docs.sentry.io/platforms/javascript/sourcemaps/#uploading-source-maps-to-sentry
  • 18. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 18 เรื่องฮา ๆ แต่เจ็บ
  • 19. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 19
  • 20. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 20 Listing
  • 21. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 21 Using trackBy in ngFor Ensure only the list element that has changed will be rendered (Not all)
  • 22. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 22 Using trackBy in ngFor Ensure only the list element that has changed will be rendered (Not all)
  • 23. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 23 Listing Using ngFor directive https://angular.io/api/common/NgForOf#ngForTrackBy
  • 24. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 24 Common solution from Doc Using ngFor + trackBy https://angular.io/api/common/NgForOf#ngForTrackBy
  • 25. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 25 ทำไมไม่ช่วยกูวะ !!
  • 26. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 26 เร็วขึ้นนะ
  • 27. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 27 แต่ไม่ต้องการให้ template render ใหม่ !!
  • 28. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 28 ทำไมดีหว่า ?
  • 29. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 29
  • 30. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 30 Hard code ไปเลย แจ่ม !!
  • 31. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 31 ไม่น่าเชื่อเร็วขึ้น 30-50% เป็นสุข
  • 32. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 32 ได้แรงบัลดาลใจ
  • 33. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 33 ไปค้นหา google ต่อ
  • 34. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 34 กลับบ้านไปเขียน code
  • 35. Meetup © 2017 - 2018 Siam Chamnankit Company Limited. All rights reserved. 35 กลับบ้านไปเขียน code เขียน test ด้วยนะ