0.2.0 • Published 3 years ago
@3xpedia/library-boilerplate v0.2.0
Simple boilerplate for JavaScript libraries
Included with this boilerplate
- Eslint and prettier config
- Build scripts that output ESM, CJS and browser standalone. Write your code in ESM, export it anywhere
- As parcel does support TypeScript (among other stuff) out of the box, this library boilerplate does also support TypeScript.
How to use
- Clone this repo
- Update relevant information (license, author, ...) in the
package.json - Write your code in
./src. You can also change the exports in theindex.*files to match your needs. - You are good to publish
How to build and publish
npm run buildto build your librarynpm publishto publish it on NPM- There is also a
npm run watchscript that will watch and rebuild for local development.
What is in the build
./dist/index.cjsand./dist/index.mjsrespectively contains CJS and ESM build. The host environment should be able to pick the right build automatically../dist/index.browser.jsprovide a static build for web-browsers. It exposes you library on the global object. It also packages all the required modules from thenode_modules
How to import the lib
- CJS
const myLib = require("myLib");
// OR (depends on how you export the lib in index.cjs)
const { foo, bar } = require("myLib");- ESM
import myLib from "myLib";
// OR (depends on how you export the lib in index.mjs)
import { foo, bar } from "myLib"- Browser
<script src="myLib.js"></script>
<script>
myLib.foo();
// OR
myLib();
</script>Known issues
- No babel config is provided. Parcel does already ensure compatibility via the
browserListkey in thepackage.json. But it should be easy to add any required babel config see parcel doc - Host using a Node version prior to 12.17.0 may have troubles finding the right module system as they do not recognise the
exportskey in thepackage.json. As Node 12.x has reached EOL in April 2022, I decided this is a non-issue even if easily fixable.