Skip to content

Get esbuild-compatible targets from a browserlist config or project

License

Notifications You must be signed in to change notification settings

bogdanailincaipnt/browserslist-to-esbuild

 
 

Repository files navigation

browserslist-to-esbuild

Use browserslist with esbuild.

Allows you to use browserslist and pass the correct browsers to esbuild's target option.

Install

You have to install the browserslist package as well in your project:

npm install --save-dev browserslist browserslist-to-esbuild

or

yarn add --dev browserslist browserslist-to-esbuild

Usage

You can call browserslistToEsbuild() directly in your esbuild.mjs script, it will look for your browserslist config in either package.json or the .browserslistrc.

It will return an esbuild-compatible array of browsers.

import { build } from 'esbuild'
import browserslistToEsbuild from 'browserslist-to-esbuild'

await build({
  entryPoints: ['input.js'],
  outfile: 'output.js',
  bundle: true,
  target: browserslistToEsbuild(), // --> ["chrome79", "edge92", "firefox91", "safari13.1"]
})

Otherwise, you can pass yourself a browserslist string or array to the function.

browserslistToEsbuild('>0.2%, not dead')

API

browserslistToEsbuild(browserslistConfig?, options?)

browserslistConfig

Type: string | string[] | undefined

A string or array of strings of browsers compatible with browserslist. If none is passed, a browserslist config is searched in the script running directory.

options

Type: object | undefined

An object containing the options that will be forwarded to browserslist. You can check out the browserslist options documentation to see all the options available.

CLI

You can also use this package on the cli to test out the command in your project. If no argument is passed, the browserslist config is searched in the script running directory.

Here is some example usage:

$ npx browserslist-to-esbuild
chrome109 edge118 firefox115 ios15.6 opera102 safari15.6

$ npx browserslist-to-esbuild '>0.2%, not dead'
chrome103 edge87 firefox115 ios12.2 opera102 safari14.1

$ npx browserslist-to-esbuild '>0.2%' 'not dead'
chrome103 edge87 firefox115 ios12.2 opera102 safari14.1

About

Get esbuild-compatible targets from a browserlist config or project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%