What is @mdn/browser-compat-data?
@mdn/browser-compat-data is a comprehensive dataset that provides browser compatibility information for various web technologies, including HTML, CSS, JavaScript, and more. It is maintained by MDN Web Docs and is useful for developers who need to know which features are supported by different browsers.
What are @mdn/browser-compat-data's main functionalities?
Check CSS property support
This feature allows you to check the browser compatibility of a specific CSS property. In this example, it checks the compatibility of the 'border-radius' property.
const bcd = require('@mdn/browser-compat-data');
const css = bcd.css.properties;
console.log(css['border-radius']);
Check JavaScript API support
This feature allows you to check the browser compatibility of a specific JavaScript API. In this example, it checks the compatibility of the 'Promise' API.
const bcd = require('@mdn/browser-compat-data');
const js = bcd.javascript.builtins;
console.log(js['Promise']);
Check HTML element support
This feature allows you to check the browser compatibility of a specific HTML element. In this example, it checks the compatibility of the 'video' element.
const bcd = require('@mdn/browser-compat-data');
const html = bcd.html.elements;
console.log(html['video']);
Other packages similar to @mdn/browser-compat-data
caniuse-lite
caniuse-lite is a smaller, more compact version of the data from caniuse.com. It provides browser support tables for various web technologies. Compared to @mdn/browser-compat-data, caniuse-lite is more lightweight and focuses on providing quick access to compatibility data.
browserslist
browserslist is a tool that allows you to specify which browsers you want to support in your project. It uses data from caniuse-lite to determine browser compatibility. While @mdn/browser-compat-data provides detailed compatibility information, browserslist helps you configure your project to support specific browsers.
@mdn/browser-compat-data
https://github.com/mdn/browser-compat-data
The browser-compat-data
("BCD") project contains machine-readable browser (and JavaScript runtime) compatibility data for Web technologies, such as Web APIs, JavaScript features, CSS properties and more. Our goal is to document accurate compatibility data for Web technologies, so web developers may write cross-browser compatible websites easier. BCD is used in web apps and software such as MDN Web Docs, CanIUse, Visual Studio Code, WebStorm and more.
Read how this project is governed.
Chat with us on Matrix at chat.mozilla.org#mdn!
Installation and Import
NodeJS
You can install @mdn/browser-compat-data
as a node package.
npm install @mdn/browser-compat-data
yarn add @mdn/browser-compat-data
Then, you can import BCD into your project with either import
or require()
:
import bcd from '@mdn/browser-compat-data' with { type: 'json' };
const { default: bcd } = await import('@mdn/browser-compat-data', {
with: { type: 'json' },
});
import bcd from '@mdn/browser-compat-data' assert { type: 'json' };
const { default: bcd } = await import('@mdn/browser-compat-data', {
assert: { type: 'json' },
});
import bcd from '@mdn/browser-compat-data/forLegacyNode';
const { default: bcd } = await import('@mdn/browser-compat-data/forLegacyNode');
const bcd = require('@mdn/browser-compat-data');
Deno/Browsers
You can import @mdn/browser-compat-data
using a CDN.
import bcd from 'https://unpkg.com/@mdn/browser-compat-data' with { type: 'json' };
const { default: bcd } = await import(
'https://unpkg.com/@mdn/browser-compat-data',
{
with: { type: 'json' },
}
);
import bcd from 'https://unpkg.com/@mdn/browser-compat-data' assert { type: 'json' };
const { default: bcd } = await import(
'https://unpkg.com/@mdn/browser-compat-data',
{
assert: { type: 'json' },
}
);
const bcd = await fetch('https://unpkg.com/@mdn/browser-compat-data').then(
(response) => response.json(),
);
Other Languages
You can obtain the raw compatibility data for @mdn/browser-compat-data
using a CDN and loading the data.json
file included in releases.
https://unpkg.com/@mdn/browser-compat-data/data.json
Usage
Once you have imported BCD, you can access the compatibility data for any feature by accessing the properties of the dictionary.
const support = bcd.css.properties.background.__compat;
const support = bcd['api']['Document']['body']['__compat'];
Package contents
The @mdn/browser-compat-data
package contains a tree of objects, with support and browser data objects at their leaves. There are over 15,000 features in the dataset; this documentation highlights significant portions, but many others exist at various levels of the tree.
The definitive description of the format used to represent individual features and browsers is the schema definitions.
Apart from the explicitly documented objects below, feature-level support data may change at any time. See Semantic versioning policy for details.
The package contains the following top-level objects:
__meta
An object containing the following package metadata:
version
- the package version
timestamp
- the timestamp of when the package version was built
Data for Web API features.
Data for browsers and JavaScript runtimes. See the browser schema for details.
Data for CSS features, including:
at-rules
- at-rules (e.g. @media
)
properties
- Properties (e.g. background
, color
, font-variant
)
selectors
- Selectors (such as basic selectors, combinators, or pseudo elements)
types
- Value types for rule values
Data for HTML features, including:
elements
- Elements
global_attributes
- Global attributes
Data for HTTP features, including:
headers
- Request and response headers
methods
- Request methods
status
- Status codes
Data for JavaScript language features, including:
builtins
- Built-in objects
classes
- Class definition features
functions
- Function features
grammar
- Language grammar
operators
- Mathematical and logical operators
statements
- Language statements and expressions
webapp
- Web App manifest keys
Data for MathML features, including:
Data for SVG features, including:
attributes
- Attributes
elements
- Elements
Data for WebAssembly features.
Data for WebDriver features, including:
bidi
- WebDriver BiDi protocol
classic
- WebDriver Classic protocol
Data for WebExtensions features, including:
api
- WebExtension-specific APIs
manifest
- manifest.json
keys
Semantic versioning policy
For the purposes of semantic versioning (SemVer), the public API consists of:
- The high-level namespace objects documented in Package contents
- The schema definitions for browser and support data structures
- The TypeScript definitions
The details of browser compatibility change frequently, as browsers ship new features, standards organizations revise specifications, and Web developers discover new bugs. We routinely publish updates to the package to reflect these changes.
You should expect lower-level namespaces, feature data, and browser data to be added, removed, or modified at any time. That said, we strive to communicate changes and preserve backward compatibility; if you rely on a currently undocumented portion of the package and want SemVer to apply to it, please open an issue.
What isn't tracked?
Now that you know what this project is, let's mention what this project isn't. This project is not:
- An extensive description of every possible detail about a feature in a browser. We do not track UI changes, irrelevant features or irrelevant flag data.
- A source for custom features added by web frameworks (e.g. React, Vue) or corporate runtimes (e.g. AWS Lambda, Azure Functions).
- A documentation of screen reader compatibility; for screen reader compatibility, check out https://a11ysupport.io/ instead.
- The location where Baseline data is hosted; while Baseline pulls from BCD, the Baseline data is managed by the W3C WebDX Community Group on their own GitHub repo.
Issues?
If you find a problem with the compatibility data (such as incorrect version numbers) or there is a new web feature you think we should document, please file a bug.
Contributing
Thank you for your interest in contributing to this project! See Contributing to browser-compat-data for more information.
Projects using the data
Here are some projects using the data, as an npm module or directly:
Acknowledgments
Thanks to: