or Back to Future
without Webpack
@hwclass
Buildless:
data:image/s3,"s3://crabby-images/a9f18/a9f186eb58165decde013ee1527055a224d8f95a" alt=""
$ npm init
What is the first command that we run to start a web app?
Anyone still remember Bower?
data:image/s3,"s3://crabby-images/85b41/85b41aa24eea2d3ed0ad57741ce1c83350823e15" alt=""
NPM
NODE.JS PACKAGE MANAGER
NPM
Why do we start every web project by creating a package.json file?
so...
BUNDLING
Why do we need to re-bundle the whole mess into a bundle?
Early Days
-
BROWSERIFY
-
GRUNT
-
GULP
Latest Trend
-
Webpack
-
Parcel
-
Rollup
Huge node_modules!
data:image/s3,"s3://crabby-images/f5a81/f5a81423f75d2062980ce64a0f8f577177c2a5e4" alt=""
Create
React
App
200.9MB node_modules/ directory of 1,300+ different dependencies to see a
“Hello World!” app.
Create
Next
App
95,2 MB node_modules/ directory of 500+ different dependencies to see a
“Hello World!” app.
+ imagine lots of lines of code added by Webpack in build time.
Gatsby
CLI
340 MB node_modules/ directory of 7000+ different dependencies to see a
“Hello World!” app.
ES6 = () => ESM
data:image/s3,"s3://crabby-images/c537b/c537bac5603951f1bc5dcf1a3c8c13fd575a6539" alt=""
data:image/s3,"s3://crabby-images/711ca/711cad45ff4ffedcdc3447ed78a8454fe8e236d4" alt=""
How to use ESM today?
data:image/s3,"s3://crabby-images/c537b/c537bac5603951f1bc5dcf1a3c8c13fd575a6539" alt=""
Within package.json,
"exports": { "import": "./path/to/entry.js" }
or
"exports": { ".": { "import": "…" } }
add the following:
and
"type": "module"
"module": "./path/to/entry.js"
{
"module": "./esm/index.js",
"exports": {
".": "./esm/index.js"
}
}
{
"main": "./index-cjs.js",
"module": "./index-esm.js",
"exports": {
"require": "./index-cjs.js",
"import": "./index-esm.js"
}
}
web-only:
Support on Browsers: 93%
data:image/s3,"s3://crabby-images/ed0a8/ed0a86f2880d00afec385a8f35d676159675a577" alt=""
How to use:
<script type="module" src="module.js"></script>
<script nomodule src="fallback.js"></script>
<script type="module">
import { tag } from './html.js'
const h1 = tag('h1', '👋 Hello Modules!')
document.body.appendChild(h1)
</script>
// html.js
export function tag (tag, text) {
const el = document.createElement(tag)
el.textContent = text
return el
}
or as an external script:
// app.js
import { tag } from './html.js'
const h1 = tag('h1', '👋 Hello Modules!')
document.body.appendChild(h1)
and|or with fallback
<script type="module" src="app.js"></script>
But still we have packages without
ESM support? (when 2020)
data:image/s3,"s3://crabby-images/5aa33/5aa33fba070a14aad4f8d9fb662548befce108ef" alt=""
data:image/s3,"s3://crabby-images/c9e45/c9e45fbc6fea7450423d9db66e4e4b53c05e81db" alt=""
The package registry
for ES-ified code (when 2020)
data:image/s3,"s3://crabby-images/843e8/843e81d09161e407697597d533dedd5ec54efd95" alt=""
data:image/s3,"s3://crabby-images/41ed9/41ed973a41bcd3aef419205f7f89e2ee5a8cd3ee" alt=""
But still we have packages without
ESM support? (when 2021)
data:image/s3,"s3://crabby-images/1103c/1103ce730d1bdc6ad8436805604d20f7022fd29d" alt=""
Load optimized npm packages with
no install and no build tools
data:image/s3,"s3://crabby-images/eabc2/eabc28f85ba1fd13fc9f02562c4426be06bccdd6" alt=""
import confetti from 'https://cdn.skypack.dev/canvas-confetti';
confetti();
Global edge cache HTTP/3 support Upconverts old Node packages to modern ES Modules JS minification Brotli / gzip compression Polyfills JS for legacy browsers and more ...
a lightning-fast frontend build tool,
designed for the modern web
data:image/s3,"s3://crabby-images/4895d/4895d003052081500509761ff2d6edfebc6cea4a" alt=""
data:image/s3,"s3://crabby-images/7f3a8/7f3a8f772d8292c6479c811f8406fa8c3612d37d" alt=""
node_modules/react/**/* -> http://localhost:3000/web_modules/react.js
node_modules/react-dom/**/* -> http://localhost:3000/web_modules/react-dom.js
<body>
<script type="module">
import React from 'react';
console.log(React);
</script>
</body>
single-file builds
This runs directly in the browser with
`snowpack dev`
a meta framework for shipping less JS to the client
Build-time / runtime code in one file
Supports partial hydration
data:image/s3,"s3://crabby-images/e2a79/e2a7944bd0c950ef0e1eeb9b92092da040c217ab" alt=""
---
// This JavaScript code runs at build-time.
console.log('This runs at build-time');
// Tip: TypeScript is also supported out-of-the-box!
const thisWorks: number = 42;
---
<div class="example-1">
<h1>Hello world!</h1>
</div>
---
// Example: hydrating a React component in the browser.
import MyReactComponent from '../components/MyReactComponent.jsx';
---
<!-- "client:visible" means the component won't load any client-side
JavaScript until it becomes visible in the user's browser. -->
<MyReactComponent client:visible />
Supporting:
- Typescript
- JSX
- JSON
- CSS Modules
- npm packages
uses Snowpack under the hood
- React/Preact (JSX), Svelte, Vue, and web components. (Solid & lit)
- WASM
- Node built-ins
Copy of Future w/o Webpack (v2)
By Barış Güler
Copy of Future w/o Webpack (v2)
- 542