diff options
Diffstat (limited to 'docs/bundler/loaders.md')
-rw-r--r-- | docs/bundler/loaders.md | 284 |
1 files changed, 191 insertions, 93 deletions
diff --git a/docs/bundler/loaders.md b/docs/bundler/loaders.md index c8f067385..7cac75648 100644 --- a/docs/bundler/loaders.md +++ b/docs/bundler/loaders.md @@ -1,136 +1,234 @@ The Bun bundler implements a set of default loaders out of the box. As a rule of thumb, the bundler and the runtime both support the same set of file types out of the box. -`.js` `.cjs` `.mjs` `.mts` `.cts` `.ts` `.tsx` `.jsx` `.toml` `.json` +`.js` `.cjs` `.mjs` `.mts` `.cts` `.ts` `.tsx` `.jsx` `.toml` `.json` `.txt` `.wasm` `.node` -{% callout %} -The runtime also supports `.wasm` and `.node` binaries, which are not easily embedded in a bundle. These are effectively not supported by Bun's bundler. -{% /callout %} +Bun uses the file extension to determine which built-in _loader_ should be used to parse the file. Every loader has a name, such as `js`, `tsx`, or `json`. These names are used when building [plugins](/docs/bundler/plugins) that extend Bun with custom loaders. -This document describes how these extensions map onto Bun's set of built-in _loaders_. Every loader has a name, such as `js`, `tsx`, or `json`. These names are used when building [plugins](/docs/bundler/plugins) that extend Bun with custom loaders. +## Built-in loaders -{% table %} +### `js` -- Loader -- Extensions -- Description +**JavaScript**. Default for `.cjs` and `.mjs`. ---- +Parses the code and applies a set if default transforms, like dead-code elimination, tree shaking, and environment variable inlining. Note that Bun does not attempt to down-convert syntax at the moment. -- `js` -- `.cjs` `.mjs` -- **JavaScript.** Parses the code and applies a set if default transforms, like dead-code elimination, tree shaking, and environment variable inlining. Note that Bun does not attempt to down-convert syntax at the moment. +### `jsx` ---- +**JavaScript + JSX.**. Default for `.js` and `.jsx`. -- `jsx` -- `.js` `.jsx` -- **JavaScript + JSX.** Same as the `js` loader, but JSX syntax is supported. By default, JSX is downconverted to `createElement` syntax and a `jsx` factory is injected into the bundle. This can be configured using the relevant `jsx*` compiler options in `tsconfig.json`. +Same as the `js` loader, but JSX syntax is supported. By default, JSX is downconverted to plain JavaScript; the details of how this is done depends on the `jsx*` compiler options in your `tsconfig.json`. Refer to the TypeScript documentation [on JSX](https://www.typescriptlang.org/docs/handbook/jsx.html) for more information. ---- +### `ts` -- `ts` -- `.mts` `.cts` -- **TypeScript.** Strips out all TypeScript syntax, then behaves identically to the `js` loader. Bun does not perform typechecking. +**TypeScript loader**. Default for `.ts`, `.mts`, and `.cts`. ---- +Strips out all TypeScript syntax, then behaves identically to the `js` loader. Bun does not perform typechecking. -- `tsx` -- `.ts` `.tsx` -- **TypeScript + JSX**. Transpiles both TypeScript and JSX to vanilla JavaScript. +### `tsx` ---- +**TypeScript + JSX loader**. Default for `.tsx`. Transpiles both TypeScript and JSX to vanilla JavaScript. -- `json` -- `.json` -- **JSON**. JSON files are parsed and inlined into the bundle as a JavaScript object. +### `json` - ```ts - import pkg from "./package.json"; - pkg.name; // => "my-package" - ``` +**JSON loader**. Default for `.json`. - If a `.json` file is passed as an entrypoint, it will be converted to a `.js` with the parsed object as a default export. +JSON files can be directly imported. - {% codetabs %} +```ts +import pkg from "./package.json"; +pkg.name; // => "my-package" +``` - ```json#Input - { - "name": "John Doe", - "age": 35, - "email": "johndoe@example.com" - } - ``` +During bundling, the parsed JSON is inlined into the bundle as a JavaScript object. - ```js#Output - export default { - name: "John Doe", - age: 35, - email: "johndoe@example.com" - } - ``` +```ts +var pkg = { + name: "my-package", + // ... other fields +}; +pkg.name; +``` - {% /codetabs %} +If a `.json` file is passed as an entrypoint to the bundler, it will be converted to a `.js` module that `export default`s the parsed object. ---- +{% codetabs %} -- `toml` -- `.toml` -- **TOML**. TOML files are parsed and inlined into the bundle as a JavaScript object. +```json#Input +{ + "name": "John Doe", + "age": 35, + "email": "johndoe@example.com" +} +``` - ```ts - import config from "./bunfig.toml"; - config.logLevel; // => "debug" - ``` +```js#Output +export default { + name: "John Doe", + age: 35, + email: "johndoe@example.com" +} +``` - If a `.toml` file is passed as an entrypoint, it will be converted to a `.js` with the parsed object as a default export. +{% /codetabs %} - {% codetabs %} +### `toml` - ```toml#Input - name = "John Doe" - age = 35 - email = "johndoe@example.com" - ``` +**TOML loader**. Default for `.toml`. - ```js#Output - export default { - name: "John Doe", - age: 35, - email: "johndoe@example.com" - } - ``` +TOML files can be directly imported. Bun will parse them with its fast native TOML parser. - {% /codetabs %} +```ts +import config from "./bunfig.toml"; +config.logLevel; // => "debug" +``` ---- +During bundling, the parsed TOML is inlined into the bundle as a JavaScript object. + +```ts +var config = { + logLevel: "debug", + // ...other fields +}; +config.logLevel; +``` + +If a `.toml` file is passed as an entrypoint, it will be converted to a `.js` module that `export default`s the parsed object. + +{% codetabs %} + +```toml#Input +name = "John Doe" +age = 35 +email = "johndoe@example.com" +``` + +```js#Output +export default { + name: "John Doe", + age: 35, + email: "johndoe@example.com" +} +``` + +{% /codetabs %} + +### `text` + +**Text loader**. Default for `.txt`. + +The contents of the text file are read and inlined into the bundle as a string. +Text files can be directly imported. The file is read and returned as a string. + +```ts +import contents from "./file.txt"; +console.log(contents); // => "Hello, world!" +``` + +When referenced during a build, the contents are into the bundle as a string. + +```ts +var contents = `Hello, world!`; +console.log(contents); +``` + +If a `.txt` file is passed as an entrypoint, it will be converted to a `.js` module that `export default`s the file contents. + +{% codetabs %} + +```txt#Input +Hello, world! +``` + +```js#Output +export default "Hello, world!"; +``` + +{% /codetabs %} -- `text` -- `.txt` -- **Text files**. The contents of the text file are read and inlined into the bundle as a string. +### `wasm` - ```ts - import contents from "./file.txt"; - console.log(contents); // => "Hello, world!" - ``` +**WebAssembly loader**. Default for `.wasm`. - If a `.txt` file is passed as an entrypoint, it will be converted to a `.js` with the contents of the file as a default export. +In the runtime, WebAssembly files can be directly imported. The file is read and returned as a `WebAssembly.Module`. - {% codetabs %} +```ts +import wasm from "./module.wasm"; +console.log(wasm); // => WebAssembly.Module +``` - ```txt#Input - Hello, world! - ``` +In the bundler, `.wasm` files are handled using the [`file`](#file) loader. - ```js#Output - export default "Hello, world!"; - ``` +### `napi` - {% /codetabs %} +**Native addon loader**. Default for `.node`. + +In the runtime, native addons can be directly imported. + +```ts +import addon from "./addon.node"; +console.log(addon); +``` + +In the bundler, `.node` files are handled using the [`file`](#file) loader. + +### `file` + +**File loader**. Default for all unrecognized file types. + +The file loader resolves the import as a _path/URL_ to the imported file. It's commonly used for referencing media or font assets. + +```ts#logo.ts +import logo from "./logo.svg"; +console.log(logo); +``` + +_In the runtime_, Bun checks that the `logo.svg` file exists and converts it to an absolute path to the location of `logo.svg` on disk. + +```bash +$ bun run logo.ts +/path/to/project/logo.svg +``` + +_In the bundler_, things are slightly different. The file is copied into `outdir` as-is, and the import is resolved as a relative path pointing to the copied file. + +```ts#Output +var logo = "./logo.svg"; +console.log(logo); +``` + +If a value is specified for `publicPath`, the import will use value as a prefix to construct an absolute path/URL. + +{% table %} + +- Public path +- Resolved import --- -- `file` -- `.*` -- **File loader**. Any unrecognized file type is handled using the `file` loader. The file is copied into the `outdir` as-is. The name of the copied file is determined using the value of `naming.asset`. +- `""` (default) +- `/logo.svg` + +--- + +- `"/assets"` +- `/assets/logo.svg` + +--- + +- `"https://cdn.example.com/"` +- `https://cdn.example.com/` {% /table %} + +{% callout %} +The location and file name of the copied file is determined by the value of [`naming.asset`](/docs/cli/build#naming). +{% callout %} +This loader is copied into the `outdir` as-is. The name of the copied file is determined using the value of `naming.asset`. + +{% details summary="Fixing TypeScript import errors" %} +If you're using TypeScript, you may get an error like this: + +```ts +// TypeScript error +// Cannot find module './logo.svg' or its corresponding type declarations. +``` |