Press → to see first slide Press ESC to see all slides
data:image/s3,"s3://crabby-images/80e0f/80e0f5e138aeba5f7ce0dc5b5d0cc0ece3a2cf34" alt=""
Jakub Sowiński
Microfrontends: extending service-oriented architecture to front-end development
📅
7 days
⏱️
30 minutes
Service-Oriented
Architecture
Micro Frontends:
extending service-oriented architecture to frontend development
🗺️
👉 What is Micro Frontend? 📌
👉 What is Micro Frontend for?
👉 How does it work?
👉 How do we create one?
🔎 "Microfrontend"
in Google searches
data:image/s3,"s3://crabby-images/50584/50584a1956eda4e682a1f69c27aef88cda9233df" alt=""
data:image/s3,"s3://crabby-images/f195e/f195e97ce1b0639db90095c08f3ca1822c3e8016" alt=""
data:image/s3,"s3://crabby-images/924fc/924fc1fa503caaf622ab7ebaf340da3b45822d25" alt=""
data:image/s3,"s3://crabby-images/1043a/1043a98659591795558fe99902e23bc45f96e1d8" alt=""
data:image/s3,"s3://crabby-images/05995/059951358635960047c236e00ea6d936173a8671" alt=""
data:image/s3,"s3://crabby-images/c3902/c39023551c21b1ffb5cdef7915b509d171c8c19c" alt=""
🤖
Micro
Frontend
🤖🤖🤖
Micro
Frontend
Architecture
data:image/s3,"s3://crabby-images/7423e/7423ea8dd06511ce70264f73314947ed7300a846" alt=""
data:image/s3,"s3://crabby-images/cc307/cc30754311490e985e8e8ce98bd2cc652e690997" alt=""
data:image/s3,"s3://crabby-images/f8c97/f8c970cc9a2c66e12d6d8250acc4c204e5b282f8" alt=""
data:image/s3,"s3://crabby-images/277eb/277eba4b8735fe431c01094baa0a2bd7b4a52934" alt=""
data:image/s3,"s3://crabby-images/64d38/64d3806be1cccc86ba603e145fdfc08358cd1164" alt=""
data:image/s3,"s3://crabby-images/abc6d/abc6d3843f41241ab96eb17fa99f3f7917facebd" alt=""
data:image/s3,"s3://crabby-images/aec7e/aec7e5c43323e9d18c47820261c6330c2d552e58" alt=""
data:image/s3,"s3://crabby-images/c2a09/c2a09499b17bec4f60e9240bd4d678d593da8268" alt=""
🗺️
👉 What is Micro Frontend?
👉 What is Micro Frontend for? 📌
👉 How does it work?
👉 How do we create one?
data:image/s3,"s3://crabby-images/be2f6/be2f62255ba04f95a30af640a6a15402473041ca" alt=""
data:image/s3,"s3://crabby-images/0dcfe/0dcfe6ae2b8961c91d5b16a5ba65475e1bf3df14" alt=""
data:image/s3,"s3://crabby-images/bf301/bf301d56499b1d42a45bf56375b9bfefb5452b72" alt=""
👩🎨
Small, autonomous teams
with customer focus
🔭 Reduced scope
⚡⚡⚡
Speed and agility
of development
🎨 Progressive refactoring
Architecture is
a tool ⛏️
🏁
Start with monolith
Fragmentation
👍 expectations vs reality 👎
🗺️
👉 What is Micro Frontend?
👉 What is Micro Frontend for?
👉 How does it work? 📌
👉 How do we create one?
data:image/s3,"s3://crabby-images/0dcfe/0dcfe6ae2b8961c91d5b16a5ba65475e1bf3df14" alt=""
data:image/s3,"s3://crabby-images/b35d4/b35d450b617e9a8d4f0a87ba2502f8da7348bb06" alt=""
data:image/s3,"s3://crabby-images/b61c0/b61c04f49475c5a798dcadcbe698a0d7be057b0c" alt=""
SSI:
HTML template
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title>Feed me</title>
</head>
<body>
<h1>🍽 Feed me</h1>
<!--# include file="$PAGE.html" -->
</body>
</html>
SSI: server
server {
listen 8080;
server_name localhost;
root /usr/share/nginx/html;
index index.html;
ssi on;
rewrite ^/$ http://localhost:8080/browse redirect;
location /browse {
set $PAGE 'browse';
}
location /order {
set $PAGE 'order';
}
location /profile {
set $PAGE 'profile'
}
}
data:image/s3,"s3://crabby-images/f4603/f4603c8d969518e0f28f0c96e4eebd16e4af5b41" alt=""
data:image/s3,"s3://crabby-images/97b60/97b60b32b0ad7b0d1ebd9ba3ebe8c8bbc4fe9471" alt=""
Templating Engine: routes
routeMap:
"/": "/index.html"
"/thiscompany": "/companyHub/pages/thisCompany.html"
"/jobs": "/companyHub/pages/jobs.html"
"/contacts": "/companyHub/pages/contacts.html"
"/reviews": "/companyHub/pages/reviews.html"
Templating Engine: template
<fragment id="ch-background-image" slot="ch-background-image"
timeout="30000" async></fragment>
<fragment id="ch-meta-data-header" slot="ch-header"
timeout="30000" async></fragment>
<fragment id="ch-jobs" slot="ch-block-main"
timeout="30000"></fragment>
<fragment id="ch-assets" slot="ch-block-end"
timeout="30000" async></fragment>
Templating Engine: fragments
fragments:
ch-assets: http://localhost:8080/assetslinks
ch-background-image: http://localhost:8080/v1/background
/companyId/{companyId}/lang/{langName}/?{additionalParams}
ch-jobs: http://localhost:8080/v1/jobs/companyId/{companyId}
/lang/{langName}/?{additionalParams}
ch-meta-data-header: http://localhost:8080/v1/header
/companyId/{companyId}/lang/{langName}/?{additionalParams}
Templating Engine:
other responsibilities
👉 standard libraries
👉 tracking
👉 a/b tests
data:image/s3,"s3://crabby-images/7a3c8/7a3c8ccd75db7ee963cda71ab1b0604d93c3adc1" alt=""
data:image/s3,"s3://crabby-images/a17c7/a17c75fb997847efccfa3be83704ddec62300138" alt=""
PubSub: Subscribe
import {
PubSub,
CANDIDATE_PROFILE_EVENTS,
} from '@stepstone/pub-sub';
class LoginModal extends React.Component {
public componentDidMount() {
PubSub.subscribe(
CANDIDATE_PROFILE_EVENTS.SHOW_LOGIN_MODAL,
(msg, data) => { /* ... */ }
);
}
}
PubSub: Publish
PubSub.publish('CANDIDATE_PROFILE_SHOW_LOGIN_MODAL');
data:image/s3,"s3://crabby-images/bde80/bde80c15992a8cc6735d8121d318e539c5434c30" alt=""
Native events
PubSub.subscribe(...);
PubSub.publish(...);
element.addEventListener(...);
element.dispatchEvent(...);
CustomEvent API: availability
data:image/s3,"s3://crabby-images/cff74/cff74ec49cea7d1af896776616d06492a8f20258" alt=""
PubSub vs CustomEvent API
PubSub.subscribe(
'myEvent',
(msg, data) => { /* ... */ }
);
PubSub.publish('myEvent');
element.addEventListener(
'myEvent',
(msg, data) => { /* ... */ }
);
element.dispatchEvent(
new CustomEvent('myEvent')
);
Alternative for communication
data:image/s3,"s3://crabby-images/50991/509915d1c15165fa3eaefb1ec5abbaa454889fc3" alt=""
data:image/s3,"s3://crabby-images/dd168/dd1686f57f1af5d57a98fb1fc0e0e232be858c99" alt=""
data:image/s3,"s3://crabby-images/8ad2b/8ad2b5fbd1dc9beabe40698f76d1f614ef82cd38" alt=""
data:image/s3,"s3://crabby-images/68d11/68d115a4745d73bc695056c26fe7c6e2028f4b9d" alt=""
data:image/s3,"s3://crabby-images/e49a7/e49a779f9d032ff1df1abb46f3faa850721adaa3" alt=""
🗺️
👉 What is Micro Frontend?
👉 What is Micro Frontend for?
👉 How does it work?
👉 How do we create one? 📌
data:image/s3,"s3://crabby-images/99624/99624f1fca18f382ee27d19f57975e6389e4e1f0" alt=""
data:image/s3,"s3://crabby-images/aa786/aa786128caf1ec97f30322ad0243decaa01aca77" alt=""
Standardization and automation
Automated project
creation
⚙️⚙️⚙️
📦 code repository
🔨 build plan
🎯 deployment plan
🔨 Build
data:image/s3,"s3://crabby-images/4551e/4551e30798f541e1c37be5ffe1b6cb7ac7e55b1e" alt=""
data:image/s3,"s3://crabby-images/87b9d/87b9d334c2fc037154cd52c06041a931a1815e81" alt=""
data:image/s3,"s3://crabby-images/038b9/038b9b2cd30adc2b04c7c2e340b15ba74c6e05af" alt=""
🎯 Deployment
data:image/s3,"s3://crabby-images/10333/103330e24f2f14dfc9bc974676ad120ad4a42336" alt=""
data:image/s3,"s3://crabby-images/0b3f5/0b3f5e179468976e5b588c824992628c123c67ee" alt=""
💀 App skeleton
👉 code style
👉 code samples
👉 build and deployment scripts
data:image/s3,"s3://crabby-images/29ecb/29ecb673bf34c14bd73da60410cf9b1a0a3736e4" alt=""
💀 App skeleton
data:image/s3,"s3://crabby-images/e4abd/e4abda76c793d48fab3b740bf5315dbf633200f2" alt=""
🍔 Standard tech stack
👉 easy to switch teams and projects
👉 easy to share knowledge and solutions
👉 better performance
Frontend vendor package
⚛️ React
⚛️ React DOM
📜 polyfills
📚 other common libraries
🖌️ Styling
🖌️ Styling with SASS
data:image/s3,"s3://crabby-images/8d417/8d417fd80bd5ec59b25a0c07dca2cb15db77ac7f" alt=""
🖌️ Styling with SASS: issues
📜 over 100 versions in 1 year
🏋️ repository of 135 megabytes
🖌️ Styling with CSS-in-JS
data:image/s3,"s3://crabby-images/a8f1d/a8f1d228579085cd0d8856fbbf53816c218c1891" alt=""
🖌️ Styling with CSS-in-JS: component
import styled from '@stepstone/dresscode-react';
const Example = styled.section`
padding: 0 ${(props) => props.theme.spacings.spacingXS};
background-color: ${(props) => props.theme.colors.accent};
font-size: ${(props) => props.theme.typography.fontSizeM};
`;
🖌️ Styling with CSS-in-JS:
Theme Provider
import {
ThemeProvider,
getThemeVariables
} from '@stepstone/dresscode-react';
const theme = getThemeVariables('stepstone');
ReactDOM.render(
<ThemeProvider theme={theme}>
<Example/>
</ThemeProvider>
document.getElementById('root')
);
🖌️ Styling with CSS-in-JS: theme
{
"breakpoints": {
"screenXSMax": "767px",
"screenSMax": "767px",
"screenMMin": "768px",
// ...
},
"colors": {
"black": "#222222",
"grey": "#8e97a4",
"white": "#ffffff",
// ...
},
// ...
}
📚 Library of components
📚 Library of components
(monorepo)
data:image/s3,"s3://crabby-images/e2200/e220028173c969ea138d6c00f6f5494aa1709b07" alt=""
⚔️ Battle test
📚 Adding components
⚔️ battle test
🙋♀️ propose
📋 review
🙏 merge and release
🔄 replace
📚 Atomic design
data:image/s3,"s3://crabby-images/6b18b/6b18b2805aa1ccb2f486dc3c15a0f089747f2fca" alt=""
📚 Atomic design
data:image/s3,"s3://crabby-images/2ec07/2ec0757871f0b8db476ad223b69098f85dd51fe3" alt=""
data:image/s3,"s3://crabby-images/a2c1b/a2c1b905a8bf9f6cc212ec231964b703bd35aac3" alt=""
data:image/s3,"s3://crabby-images/37ddb/37ddb7f2ca3c067b82510841714e4790b6377ae9" alt=""
👨💻
📚
👩🎨
📚
👨💻👩🎨
📚
✔️ Testing
Tests pyramid
data:image/s3,"s3://crabby-images/f6bc5/f6bc59f66f60f27d66240827aec4079b2b66e35c" alt=""
🔨 Build
👉 run unit tests
👉 check code coverage
👉 run performance and accessibility tests
Tests pyramid
data:image/s3,"s3://crabby-images/f6bc5/f6bc59f66f60f27d66240827aec4079b2b66e35c" alt=""
✔️ Automated Tests Framework
data:image/s3,"s3://crabby-images/9eecf/9eecfbf0c0a3f62ba71630adde5987cea9f5e9ec" alt=""
✔️ Additional testing
data:image/s3,"s3://crabby-images/b3897/b3897aa0f78171ccb4ee22ed4fe693d0b3d94d4c" alt=""
data:image/s3,"s3://crabby-images/c0131/c0131a8fcadc6130d58e4a58feeec169676fd7fb" alt=""
data:image/s3,"s3://crabby-images/d812a/d812a4577ea92581096c04aa65ba99f807383296" alt=""
💂 Custodian
💂 Custodians of ATF
data:image/s3,"s3://crabby-images/8fe2a/8fe2ab673bd30f7f69a316d890acf4e7f9909b1e" alt=""
💂 In need for custodian
👉 templating engine
👉 application skeleton and related processes
👉 common styling
👉 library of components
👉 end-to-end tests
👉 tracking
👉 a/b tests
💂 Custodians of frontend
data:image/s3,"s3://crabby-images/dab40/dab403679633beb187133ef7001bf62a22a724ca" alt=""
🗺️
👉 What is Micro Frontend?
👉 What is Micro Frontend for?
👉 How does it work?
👉 How do we create one?
👍
👎
📚 Learning resources
Thank you
Press ← to see last slide Press ESC to see all slides