How to get started
Use defaults
if you’re building a web application for
the global audience.
Use node 18
if you’re building a Node.js application,
e.g., for server-side rendering.
Autoprefixer, Babel and many other tools will find target browsers automatically if you add the following to package.json:
"browserslist": [
"defaults and fully supports es6-module",
"maintained node versions"
]
Query syntax
Start with the default configuration
You can pick a sound set of versions with the defaults
query which is
a shortcut for > 0.5%, last 2 versions, Firefox ESR, not dead
.
It matches recent versions of popular and supported browsers worldwide and includes
Firefox Extended Support Release which is updated roughly annually.
The defaults
query was thoroughly designed by the
Browserslist community.
It helps promote best practices and avoid common pitfalls.
Select browser versions with certain usage
You can pick versions that have more than or less than a certain size of the audience worldwide, in a region, or in a country. You can also use the visitor data of your own website.
Examples
> 5%
all versions with > 5% of the audience worldwide.>= 5% in US
same as above but in the US.>= 5% in alt-AS
same as above but in Asia.
Beware
- You may exclude the most recent versions of all browsers that have been just
released. Please always add
last … versions
to include them back. - You can exclude your global audience. Please be careful when narrowing the audience to a region or a country.
- You may include
dead
versions. Please consider addingnot dead
.
Advanced
> 5% in my stats
versions with > 5% of usage within your own audience.> 5% in circle-ci stats
versions with > 5% of usage within the audience data from shareable configuration, available as custom stats.cover 99.5%
the smallest set of popular versions with collective usage over 99.5% of the audience worldwide.cover 99.5% in CN
same as above but in China.cover 99.5% in alt-EU
same as above but in Europe.
Select recent browser versions
You can pick a few recent browser versions.
Examples
last 2 versions
last 2 versions of each browser.last 2 Chrome versions
same as above but just Chrome.
Beware
- You might exclude older versions still used by a substantial audience.
Please always add
> …
to include them back. - You may pick
dead
browsers like Internet Explorer. Always uselast … versions
withnot dead
.
Advanced
last 2 major versions
all minor and patch releases of the last 2 major versions.last 2 Safari major versions
same as above but just Safari.unreleased versions
alpha and beta versions.unreleased Chrome versions
same as above but just Chrome.since 2020-01-15
versions released since Jan 15, 2020.since 2020-01
versions released since January 2020, inclusive.since 2020
versions released since 2020, inclusive.last 3 years
same as above if you run this query in 2022.
Select specific browser versions
You can pick browser versions or a version range of your choice.
Examples
ChromeAndroid 103
mobile Chrome version 103.Firefox > 20
desktop Firefox versions newer than 20.iOS >= 13.2
mobile Safari version 13.2 and newer.not Firefox ESR
removes specific version.
Beware
- Make sure that your audience uses specific versions
(e.g., in a corporate setting) or
that your application is not built to work with specific versions
(e.g., it’s a bleeding-edge demo
project). Please consider using
last … versions
or> …
to include more versions. - Note, that Opera Mini has special version
all
.not op_mini all
is not a special query.
Advanced
ie 6-8
an inclusive range of Internet Explorer versions.Firefox ESR
the latest Firefox Extended Support Release.
Select specific Node.js versions
You can pick Node.js versions or a version range of your choice. Useful if you know for sure the runtime configuration of your server-side code.
Examples
node 10
latest10.x.x
Node.js version.node 10.4
latest10.4.x
Node.js version.node > 16
all Node.js versions newer than16.0.0
.last 2 node versions
two latest Node.js releases.last 2 node major versions
two last major-version Node.js releases.
Advanced
maintained node versions
all Node.js versions currently maintained by Node.js Foundation.current node
the Node.js version used by Browserslist right now.
Select browser versions that support a certain feature
You can pick browser versions that support features from the Can I Use database. See the caniuse-lite repository for the full list of features.
Examples
fully supports es6-module
versions that fully support JavaScript modules via script tag.partially supports css-grid
versions that fully or partially supports CSS Grid Layout.
Beware
supports …
is an alias forpartially supports …
, however as its naming is ambigious, prefer usingpartially supports
to make your intent of including partially supported browsers clear.- These queries rarely work well on their own. Please consider combining them with other queries.
Combine multiple queries into one
You can combine versions matched by multiple queries with or
or ,
; you can
intersect them with and
. You can also negate any query with not
if it’s
not the first one in your list.
Examples
-
> 0.5%, last 2 versions
combines> 0.5%
withlast 2 versions
. > 0.5% or last 2 versions
same as above.> 0.5% and last 2 versions
intersects> 0.5%
withlast 2 versions
.> 0.5% and not last 2 versions
removeslast 2 versions
from> 0.5%
.
Beware
- A query with
not
can't be the left-hand one in the list. - A query with
not
is always joined to the left-hand one withand
, even ifor
or,
are used.
Advanced
-
The following queries yield the same result:
> 0.5% and not last 2 versions
,> 0.5% or not last 2 versions
,> 0.5%, not last 2 versions
.
Exclude unmaintained browser versions
You can combine your queries with
not dead
to exclude dead
browsers, i.e.,
browsers without official support or updates for more than 24 months.
Right now these include IE 11, IE Mobile 11, BlackBerry 10, BlackBerry 7,
Samsung 4, Opera Mobile 12.1, and all versions of Baidu.
Examples
> 0.2% and not dead
excludesdead
versions from versions matched by> 0.2%
.
Why Browserslist
Browserslist helps you keep the right balance between browser compatibility and bundle size. With Browserslist, you will cover wider audience and have smaller bundle size.