This is an optimized workflow for those implementing unbundled builds for web components. The goal is to provide the easiest integration for unbundled builds, made popular by CDNs in large organizations. You have to use yarn because it supports "flat": true,
which is required for unbundling to work
Check out the advanced HTML file to see what's happening. Your site hydrates based on finding tags that are undefined. You'd put these in your application or on a CDN and then the integration methodology is the same every time regardless of app!
This is a starting point to do a build. Here's how to fork and customize it to be your own:
- Install yarn
git clone https://github.com/elmsln/unbundled-webcomponents.git
this repocd unbundled-webcomponents/app
to move into the directoryyarn add
to add / install new elements or editapp/package.json
directly- reference all the elements you want to import in
app/dist/app.js
or reference them inapp/dist/index.html
yarn install
to install dependencies- run
yarn run build
which will generate a build - copy the
/app/dist/
folder to your server / app location - add
<script src="./dist/build.js"></script>
to the bottom of your app / CMS or reviewapp/index.html
orapp/advanced.html
for more complete examples
app/polymer.json
has a extraDependencies
property that accepts GLOBs to match files / assets not going to be caught by the bundler. The bundler will find anythign directly referenced (like import "whatever.js";
) but will miss dynamically created things such as style.css
file references in the HTML of a component. Adding to this array the specific additional assets to include helps ensure that everything is included in the output of the bundler.
Wait... I didn't think this was a bundler?! Well, polymer.json happens to do unbundled builds. It is a bundler / compiler but we're leveraging it just for the compiling capabilites and multiple output targets it provides. As a result, it does have some bundler-isms like having to define additional assets to include in the output, though they are left unbundled as well :)
- download this repo
- add new web components via
yarn add @lrnwebcomponents/h-a-x
- add
import "@lrnwebcomponents/h-a-x/h-a-x.js";
to theapp/src/app.js
file - do the build routine spelled out above
- after
yarn run build
, rename theapp/dist/
folder towebcomponents
- place this in
sites/all/libraries/
- You should now have everything in place for this to be wired up
- If you are using a CDN approach where elements power multiple sites
- If you build your app as if there is unbundled references and want to leverage optimizations as a result
- If you are using a CMS or application that controls its own JS via a different workflow, this is probably the safer option
- This is a stepping stone to the future. In the next few years unbundling will be possible without tooling thanks to importmaps
- Your running an HTTP/2 server / CDN and know it's faster!
- anti-pattern in the JS community of today
- still uses
polymer build
to keep things separate - webpack / rollup by themselves will make smaller asset bundles and your shipping 1 stand alone app as opposed to several sites across a CDN
This has a configuration of polymer.json, a format used by the polymer CLI in order to create 2 builds of your assets.
- es6+ - This is labeled es6 but is running es8 capable build which all Evergreen browsers support.
- es5-amd - compiled to work on IE11, older versions of Edge, Firefox and Safari
This uses the polymer CLI for the time being. Once other plugins are written to do in-place, unbundled file building we'll update but for now it does a great job and has no requirement on using polymer in your project as it's just for commandline.
The file in /build.js
does feature detection in order to establish if this is an ESM capable platform or needs a different build at run time. This reduces the integration with your platform / CMS / application down to two lines of <script>
tags. The 1st adds support for CDNs as well as an option for forceUpdate
which if the browser can't serve the build.js file it will force the user to a page asking them to upgrade.
We feature detect import()
which 90+% of traffic supports as of end of 2019 and inject ES module based <script type="module">
imports. From there we try and detect which polyfills are needed based on the platform.
It has been heavily battle tested and is used in production in mutliple domains and websites.
This approach was developed by Penn State and tested by The US National Archives for accuracy.