The Angular World
data:image/s3,"s3://crabby-images/b7fb1/b7fb1385b1f65ae1c355771750d1004bcd72b3ee" alt=""
Suguru Inatomi
data:image/s3,"s3://crabby-images/34d8c/34d8c500b99989d6bb132417b1d96917b42c995c" alt=""
2018-03-24
https://goo.gl/G3phq1
Agenda
1. Angular Introduction
2. Angular Roadmap
3. Angular & real world
1. Angular Introduction
-
A framework for web front-end app
-
A platform for integrated development
-
An ecosystem for developers
Angular is ...
Angular as a framework
Full-stack for modern web app
Official Packages
-
@angular/core
-
@angular/core/testing
-
@angular/common
-
@angular/forms
-
@angular/http
-
@angular/router
-
@angular/platform-browser
-
@angular/platform-server
-
...
-
Batteries included!
-
Save time to find awesome 3rd-party packages
-
-
Easy to learn
-
Shareable knowledge in communities
-
-
Qualified
-
Always maintained, well-tested and up-to-date
-
Benefits
Angular as a platform
Angular Platform
-
Angular Language Service
-
Angular CLI (Schematics)
-
Stackblitz
-
codelyzer
Developer Tools
Angular Language Service
Types in the template
data:image/s3,"s3://crabby-images/e0441/e04415c3859378d36842c0470daeb874f582b203" alt=""
data:image/s3,"s3://crabby-images/0d87a/0d87aa8d691872f863e761b962524f7eddbd88d4" alt=""
Angular CLI
Easy to develop Angular apps
data:image/s3,"s3://crabby-images/09fbd/09fbdc8913225e9f40f5a7b84df5d2c60119c192" alt=""
data:image/s3,"s3://crabby-images/7856e/7856e2a3ef6781d2bbd7c4dc2903aef9f40e5336" alt=""
codelyzer
tslint rules for Angular
data:image/s3,"s3://crabby-images/79b1f/79b1fe3379992d4e42c9498899fa3855f38e5769" alt=""
Stackblitz
data:image/s3,"s3://crabby-images/a94ca/a94ca3d8d506112a3b2a54466f977adb4b341ff4" alt=""
data:image/s3,"s3://crabby-images/b8de7/b8de7d81128c80728a0a91e3e7c89959317e9042" alt=""
Angular Platform
-
Progressive Web Apps
-
Angular Service Worker
-
App Shell Pre-rendering
-
-
Ionic
-
Angular with Native APIs
-
-
NativeScript
-
Native app with Angular
-
Angular for Mobile
Progressive Web Apps
Angular CLI Integration
data:image/s3,"s3://crabby-images/cd0f1/cd0f15e69b9b9c979e34232aeab37e2579edee15" alt=""
Ionic
Native app with Angular and WebView
data:image/s3,"s3://crabby-images/2afd1/2afd1dd48ebce8b5b1f09287da84e6ade1e95e32" alt=""
NativeScript
Angular component => Native UI
data:image/s3,"s3://crabby-images/70830/70830aa514a8787c9c8ad942a38bfc6792119998" alt=""
data:image/s3,"s3://crabby-images/328e5/328e539c16e257a8343e4862e72d8096d66c7011" alt=""
Angular Platform
-
Angular Material
-
Component Dev Kit
-
Angular Elements
Development Kit
Angular Material
Material Design for Angular
data:image/s3,"s3://crabby-images/fa672/fa672d0ea8be1bc2b29f6f6470b98930846ab172" alt=""
Component Dev Kit
The Angular CDK gives developers solid, well-tested tools
to add common interaction patterns with minimal effort.
data:image/s3,"s3://crabby-images/fe59c/fe59ca7e08319b172644a150bc12e219eb9310a4" alt=""
Angular Elements
Angular component as a Custom Elements
-
Good for team development
-
Angular CLI: Collection of best practices
-
codelyzer: Keep code clean
-
UI components
-
-
Codebase sharing
-
Web app / Native app
-
Web Components
-
Benefits
Angular as an ecosystem
> 1 million developers
ngAtlanta 2018 keynote
Large community
ngAtlanta 2018 keynote
-
Semantic Versioning
-
Major.Minor.Patch
-
-
Time-based Releasing
-
Patch / week
-
Minor / month
-
Major / 6 months
-
-
Validated at Google
-
Google uses master HEAD version
-
Angular release cycle
-
1 year, critical fixes and security patches
Angular LTS
-
Angular (a.k.a. Angular v2+) is majority.
-
AngularJS (a.k.a. Angular v1) is (nearly) over.
-
v1.7 (June): Final version
-
3 years LTS: 2018-07-01 => 2021-06-30
-
-
No reason to choose AngularJS today.
Angular vs AngularJS
data:image/s3,"s3://crabby-images/1a423/1a42390a6f85455b72741c2754c23d49acdf611a" alt=""
data:image/s3,"s3://crabby-images/ba248/ba2481bbcd0d5a7841138c4e3e4a2d2b5c629a52" alt=""
Angular(JS) in Google
data:image/s3,"s3://crabby-images/bf143/bf143acedbc1441592ca2527325fcd84dd3e388a" alt=""
AngularConnect 2017 keynote
Angular in Production
ng-conf 2017 keynote
data:image/s3,"s3://crabby-images/dfb69/dfb6947cf16047b0ca4299e87e117174dad19e08" alt=""
Angular in Japan
- ng-japan/who-use-angular-in-japan
-
23 companies are listed.
- Add your company!
2. Angular Roadmap
-
Experimental new ideas
-
Component Dev Kit
-
Schematics
-
Angular Elements
-
ngIvy
-
ABC
-
Angular Labs
data:image/s3,"s3://crabby-images/ac281/ac2813a9f188e1e350dbc500e9ec1c2ecf0f9d2c" alt=""
Angular Elements
Angular for www
-
Angular components everywhere
-
PoC: Angular Material => CE
-
Usecase: UI library / Widgets
-
Introducing to angular.io
-
-
Early Adaptor: `yarn angular/elements-builds`
data:image/s3,"s3://crabby-images/adf5f/adf5fd32beb10b8343150f6890849481750b9a81" alt=""
ngIvy
The 4th-generation
- Internal view engine renewal
- Goal
- Faster
- Smaller
- Simpler
- 3kB Hello World app
- Optional in v6
data:image/s3,"s3://crabby-images/8cb99/8cb996f9d097c1af47dafb00881869bf72b803a6" alt=""
Angular Buildtools Convergence
or "Angular + Bazel + Closure compiler"
-
Toolchain used at Google
-
Fast / Scalable / Multi-Language / Extensible
-
-
Used for Angular apps @ Google
-
Used for Angular packages
-
Early Adaptor: http://g.co/ng/abc
data:image/s3,"s3://crabby-images/0b8cd/0b8cd15839d1221d940be79a5c7e3976e91fc2f9" alt=""
- Build with Bazel
- Will be integrated to Angular CLI
- Angular Elements
- Will be published as first-party
- ngIvy
- Will be stable and default
Angular in 2018
3. Angular & real world
-
Component-oriented design
-
Functional programming
-
Browsers compatibility
-
Performance
-
SEO
-
PWA! PWA!
-
Hey! New web standard is coming!
Web frontend today
data:image/s3,"s3://crabby-images/cf5c8/cf5c89b70cc6663e8b4558f255d511457d886358" alt=""
-
Single Page Application everywhere
-
Application Lifetime ≠ Page Lifetime
-
-
Mobile First => Mobile Only
-
Like more native app
-
Capability / Performance
-
-
Paradigm Shift
HTML Document => GUI Application
-
Component-based
-
Reusable view fragments
-
-
Functional / Immutable
- View = fn(State)
- Event-Driven
-
Avoid side-effects
-
Separation of concerns
-
Model-View-Whatever
-
DDD / Clean Architecture
-
Nothing new idea
Learn from predecessors
-
App-like behaviors
-
Icon on home screen
-
Splash screen
-
Device capabilities
-
Offline
-
Notification
-
Payment
-
-
Web (more reachable) +
Mobile (more conversion) => WIN!
More mobile-ish UX
Web for Business
data:image/s3,"s3://crabby-images/b70ce/b70ceaa636b01f069b5c746004ae0305dd66c00a" alt=""
-
More reliable
-
More capable
-
More performant
-
More maintainable
-
More scalable
Needs of Web
-
"Web" is NOT a single environment
-
Browsers: Chrome / Safari / Edge / Firefox / ...
-
Versions: Safari 8 / 9 / 10
-
OSs: iOS Safari / Android Chrome
-
-
Standardization vs Implementation
-
Polyfill / Downpile
-
-
=> Abstract browser-dependent code
-
React / Angular / Vue / ...
-
Web Platform
MUST run everywhere
data:image/s3,"s3://crabby-images/581c7/581c7e92aba42d42b23bda744cd88111cadd3078" alt=""
Use a framework
Angular for YOU
-
Blackbox of complex parts
-
DOM rendering
-
Web standards interop
-
Service Worker
-
etc
-
-
Easy, maintainable and scalable development
Think only about your app
-
Architecture
-
State management
-
Component design
-
-
User Experience
-
For loveable and valuable product
-
-
Not Angular's job
-
It's a Front-end engineer's job!
-
App concerns
What should we think about?
Conclusion
-
Full-stack
-
Batteries included
-
Easy to learn
-
Qualified packages
-
Validated by Google
-
-
Integrated developer tools
-
Growing ecosystem
Why is Angular popular?
-
Angular Elements
-
Angular component as Custom Elements
-
-
ngIvy
-
3kB bundle for Hello World
-
-
Bazel
-
Blazing fast build tool
-
What are coming?
What can I do?
-
Web front-end is not simple
-
SPA is a GUI Application
-
-
Mobile! Mobile! Mobile!
-
Think about your product more
-
Outsourcing to framework
-
6/16 ng-japan 2018
data:image/s3,"s3://crabby-images/a654e/a654ecd0a9781da2ea8f5cd1bc7c5f813291bed0" alt=""
Thanks!
data:image/s3,"s3://crabby-images/34d8c/34d8c500b99989d6bb132417b1d96917b42c995c" alt=""
Suguru Inatomi
The Angular World
By Suguru Inatomi
The Angular World
MANABIYA 2018
- 6,038