Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

📦 Zero-configuration bundler for tiny modules.

License

NotificationsYou must be signed in to change notification settings

developit/microbundle

Repository files navigation

microbundle

Microbundlenpmtravislicenses

Thezero-configuration bundler fortiny modules, powered byRollup.


Guide →SetupFormatsModern ModeUsage & ConfigurationAll Options


✨ Features

  • One dependency to bundle your library using only apackage.json
  • Support for ESnext & async/await(viaBabel &async-to-promises)
  • Produces tiny, optimized code for all inputs
  • Supports multiple entry modules(cli.js +index.js, etc)
  • Creates multiple output formats for each entry(CJS, UMD & ESM)
  • 0 configuration TypeScript support
  • Built-in Terser compression & gzipped bundle size tracking

🔧 Installation & Setup

1️⃣Install by running:npm i -D microbundle

2️⃣Set up yourpackage.json:

{"name":"foo",// your package name"type":"module","source":"src/foo.js",// your source code"exports": {"require":"./dist/foo.cjs",// used for require() in Node 12+"default":"./dist/foo.modern.js"// where to generate the modern bundle (see below)  },"main":"./dist/foo.cjs",// where to generate the CommonJS bundle"module":"./dist/foo.module.js",// where to generate the ESM bundle"unpkg":"./dist/foo.umd.js",// where to generate the UMD bundle (also aliased as "umd:main")"scripts": {"build":"microbundle",// compiles "source" to "main"/"module"/"unpkg""dev":"microbundle watch"// re-build when source files change  }}

3️⃣Try it out by runningnpm run build.

💽 Output Formats

Microbundle producesesm,cjs,umd bundles with your code compiled to syntax that works pretty much everywhere.While it's possible to customize the browser or Node versions you wish to support using abrowserslist configuration, the default setting is optimal and strongly recommended.

🤖 Modern Mode

In addition to the above formats, Microbundle also outputs amodern bundle specially designed to work inall modern browsers.This bundle preserves most modern JS features when compiling your code, but ensures the result runs in 95% of web browsers without needing to be transpiled.Specifically, it uses Babel's"bugfixes" mode(previously known aspreset-modules) to target the set of browsers that support<script type="module"> - that allows syntax like async/await, tagged templates, arrow functions, destructured and rest parameters, etc.The result is generally smaller and faster to execute than the plainesm bundle.

Take the following source code for example:

// Our source, "src/make-dom.js":exportdefaultasyncfunctionmakeDom(tag,props,children){letel=document.createElement(tag);el.append(...(awaitchildren));returnObject.assign(el,props);}

Compiling the above using Microbundle produces the followingmodern andesm bundles:

make-dom.modern.js(117b)make-dom.module.js(194b)
exportdefaultasyncfunction(e,t,a){letn=document.createElement(e);n.append(...(awaita));returnObject.assign(n,t);}
exportdefaultfunction(e,t,r){try{varn=document.createElement(e);returnPromise.resolve(r).then(function(e){returnn.append.apply(n,e),Object.assign(n,t);});}catch(e){returnPromise.reject(e);}}

This is enabled by default. All you have to do is add an"exports" field to yourpackage.json:

{"main":"./dist/foo.umd.js",// legacy UMD output (for Node & CDN use)"module":"./dist/foo.module.mjs",// legacy ES Modules output (for bundlers)"exports":"./dist/foo.modern.mjs",// modern ES2017 output"scripts": {"build":"microbundle src/foo.js"}}

The"exports" field can also be an object for packages with multiple entry modules:

{"name":"foo","exports": {".":"./dist/foo.modern.mjs",// import "foo" (the default)"./lite":"./dist/lite.modern.mjs",// import "foo/lite""./full":"./dist/full.modern.mjs"// import "foo/full"},"scripts": {"build":"microbundle src/*.js"// build foo.js, lite.js and full.js}}

📦 Usage & Configuration

Microbundle includes two commands -build (the default) andwatch.Neither require any options, but you can tailor things to suit your needs a bit if you like.

  • microbundle – bundles your code once and exits. (alias:microbundle build)
  • microbundle watch – bundles your code, then re-bundles when files change.

ℹ️ Microbundle automatically determines which dependencies to inline into bundles based on yourpackage.json.

Read more aboutHow Microbundle decides which dependencies to bundle, including some example configurations.

Specifying filenames in package.json

Unless overridden via the command line, microbundle uses thesource property in yourpackage.json to determine which of your JavaScript files to start bundling from (your "entry module").The filenames and paths for generated bundles in each format are defined by themain,umd:main,module andexports properties in yourpackage.json.

{"source":"src/index.js",// input"main":"dist/foo.js",// CommonJS output bundle"umd:main":"dist/foo.umd.js",// UMD output bundle"module":"dist/foo.mjs",// ES Modules output bundle"exports": {"types":"./dist/foo.d.ts",// TypeScript typings for NodeNext modules"require":"./dist/foo.js",// CommonJS output bundle"default":"./dist/foo.modern.mjs",// Modern ES Modules output bundle  },"types":"dist/foo.d.ts"// TypeScript typings}

When deciding which bundle to use, Node.js 12+ and webpack 5+ will prefer theexports property, while older Node.js releases use themain property, and other bundlers prefer themodule field.For more information about the meaning of the different properties, refer to theNode.js documentation.

For UMD builds, microbundle will use a camelCase version of thename field in yourpackage.json as export name.Alternatively, this can be explicitly set by adding an"amdName" key in yourpackage.json, or passing the--name command line argument.

Usage with{"type":"module"} inpackage.json

Node.js 12.16+ adds a new "ES Module package", which can be enabled by adding{"type":"module"} to your package.json.This propertychanges the default source type of.js files to be ES Modules instead of CommonJS.When using{"type":"module"}, the file extension for CommonJS bundles generated by Microbundle must be changed to.cjs:

{"type":"module","module":"dist/foo.js",// ES Module bundle"main":"dist/foo.cjs",// CommonJS bundle}

Additional Configuration Options

Config also can be overridded by thepublishConfig property in yourpackage.json.

{"main":"src/index.ts",// this would be used in the dev environment (e.g. Jest)"publishConfig": {"source":"src/index.js",// input"main":"dist/my-library.js",// output  },"scripts": {"build":"microbundle"  }}

Building a single bundle with fixed output name

By default Microbundle outputs multiple bundles, one bundle per format. A single bundle with a fixed output name can be built like this:

microbundle -i lib/main.js -o dist/bundle.js --no-pkg-main -f umd

Using with TypeScript

Just point the input to a.ts file through either the cli or thesource key in yourpackage.json and you’re done.

Microbundle will generally respect your TypeScript config defined in atsconfig.json file with notable exceptions being the "target" and "module" settings. To ensure your TypeScript configuration matches the configuration that Microbundle uses internally it's strongly recommended that you set"module": "ESNext" and"target": "ESNext" in yourtsconfig.json.

To ensure Microbundle does not process extraneous files, by default it only includes your entry point. If you want to include other files for compilation, such as ambient declarations, make sure to add either "files" or "include" into yourtsconfig.json.

If you're using TypeScript with CSS Modules, you will want to set"include": ["node_modules/microbundle/index.d.ts"] in yourtsconfig.json to tell TypeScript how to handle your CSS Module imports.

To ensure that your module's.d.ts type info is visible to other TypeScript projects that usemoduleResolution: 'NodeNext', add atypes key to yourpackage.json's correspondingexports mapping.

CSS and CSS Modules

Importing CSS files is supported viaimport "./foo.css". By default, generated CSS output is written to disk. The--css inline command line option will inline generated CSS into your bundles as a string, returning the CSS string from the import:

// with the default external CSS:import'./foo.css';// generates a minified .css file in the output directory// with `microbundle --css inline`:importcssfrom'./foo.css';console.log(css);// the generated minified stylesheet

CSS Modules: CSS files with names ending in.module.css are treated as aCSS Modules.To instead treat imported.css files as modules, run Microbundle with--css-modules true. To disable CSS Modules for your project, pass--no-css-modules or--css-modules false.

The default scope name for CSS Modules is_[name]__[local]__[hash:base64:5] in watch mode, and_[hash:base64:5] for production builds.This can be customized by passing the command line argument--css-modules "[name]_[hash:base64:7]", usingthese fields and naming conventions.

flagimportis css module?
nullimport './my-file.css';
nullimport './my-file.module.css';
falseimport './my-file.css';
falseimport './my-file.module.css';
trueimport './my-file.css';
trueimport './my-file.module.css';

Building Module Workers

Microbundle is able to detect and bundle Module Workers when generating bundles in theesm andmodern formats. To use this feature, instantiate your Web Worker as follows:

worker=newWorker(newURL('./worker.js',import.meta.url),{type:'module'});// or simply:worker=newWorker('./worker.js',{type:'module'});

... then add the--workers flag to your build command:

microbundle --workers

For more information see@surma/rollup-plugin-off-main-thread.

Visualize Bundle Makeup

Use the--visualize flag to generate astats.html file at build time, showing the makeup of your bundle. Usesrollup-plugin-visualizer.

Mangling Properties

To achieve the smallest possible bundle size, libraries often wish to rename internal object properties or class members to smaller names - transformingthis._internalIdValue tothis._i. Microbundle doesn't do this by default, however it can be enabled by creating amangle.json file (or a"mangle" property in your package.json). Within that file, you can specify a regular expression pattern to control which properties should be mangled. For example: to mangle all property names beginning an underscore:

{"mangle": {"regex":"^_"}}

It's also possible to configure repeatable short names for each mangled property, so that every build of your library has the same output.See the wiki for acomplete guide to property mangling in Microbundle.

Defining build-time constants

The--define option can be used to inject or replace build-time constants when bundling. In addition to injecting string or number constants, prefixing the define name with@ allows injecting JavaScript expressions.

Build commandSource codeOutput
microbundle --define VERSION=2console.log(VERSION)console.log(2)
microbundle --define API_KEY='abc123'console.log(API_KEY)console.log("abc123")
microbundle --define @assign=Object.assignassign(a, b)Object.assign(a, b)

All CLI Options

Usage$ microbundle <command> [options]Available Commandsbuild    Build once and exitwatch    Rebuilds on any changeFor more info, run any command with the `--help` flag$ microbundle build --help$ microbundle watch --helpOptions-v, --version      Displays current version-i, --entry        Entry module(s)-o, --output       Directory to place build files into-f, --format       Only build specified formats (any of modern,esm,cjs,umd or iife) (default modern,esm,cjs,umd)-w, --watch        Rebuilds on any change  (default false)--pkg-main         Outputs files analog to package.json main entries  (default true)--target           Specify your target environment (node or web)  (default web)--external         Specify external dependencies, or 'none' (default peerDependencies and dependencies in package.json)--globals          Specify globals dependencies, or 'none'--define           Replace constants with hard-coded values (use @key=exp to replace an expression)--alias            Map imports to different modules--compress         Compress output using Terser (default true when --target is web, false when --target is node)--strict           Enforce undefined global context and add "use strict"--name             Specify name exposed in UMD and IIFE builds--cwd              Use an alternative working directory  (default .)--sourcemap        Generate source map  (default true)--raw              Show raw byte size  (default false)--jsx              A custom JSX pragma like React.createElement (default h)--jsxFragment      A custom JSX fragment pragma like React.Fragment (default Fragment)--jsxImportSource  Declares the module specifier to be used for importing jsx factory functions--tsconfig         Specify the path to a custom tsconfig.json--generateTypes    Whether or not to generate types, if `types` or `typings` is set in `package.json` then it will default to be `true`--css              Where to output CSS: "inline" or "external" (default "external")--css-modules      Configures .css to be treated as modules (default null)--workers          Bundle module workers - see https://github.com/surma/rollup-plugin-off-main-thread#auto-bundling  (default false)--visualize        Generate bundle makeup visualization (stats.html)-h, --help         Displays this messageExamples$ microbundle build --globals react=React,jquery=$$ microbundle build --define API_KEY=1234$ microbundle build --alias react=preact/compat$ microbundle watch --no-sourcemap # don't generate sourcemaps$ microbundle build --tsconfig tsconfig.build.json

🛣 Roadmap

Here's what's coming up for Microbundle:

🔨 Built with Microbundle

🥂 License

MIT


[8]ページ先頭

©2009-2025 Movatter.jp