This repository contains compatibility data for Web technologies as displayed on MDN
Permalink
Failed to load latest commit information.
.vscode Add json schema data to the .vscode/settings.json file. (#2905) Oct 4, 2018
api Updates createComment support for IE and Safari (#3003) Oct 18, 2018
browsers Update chrome for android browser data (#3002) Oct 24, 2018
css fix(css): The `@-moz-document regexp(…)` function isn’t prefixed (#3009) Oct 22, 2018
html Edge 17: fieldset disabled attribute not working (#2978) Oct 24, 2018
http Fix status data for several HTTP headers (#2958) Oct 12, 2018
javascript Basic JS import support in Android WebView 61. (#3001) Oct 18, 2018
mathml/elements Add webview_android browser data (#2690) Sep 14, 2018
schemas Add descriptions to schema properties. (#2923) Oct 5, 2018
svg Sort browsers for svg/* (#2897) Oct 4, 2018
test Setup XPath compat data (#2287) Aug 27, 2018
webdriver/commands webdriver: fix typo and link to capabilities on mdn (#2930) Oct 10, 2018
webextensions Add compatibility data for menus.getTargetElement (#3016) Oct 24, 2018
xpath/axes Setup XPath compat data (#2287) Aug 27, 2018
xslt/elements Add chrome_android release data and correct invalid versions (#1356) Aug 29, 2018
.editorconfig Add .editorconfig file and fix files (#188) May 16, 2017
.gitignore gitignore: ignore log files (#2216) Jul 13, 2018
.npmignore Add VisualStudio Code extension recommendations and basic settings (#… Aug 9, 2018
.travis.yml Add npm as a deployment provider to travis Oct 30, 2017
CODE_OF_CONDUCT.md Add code of conduct (#181) May 8, 2017
CONTRIBUTING.md Fix install instructions to use full `npm install` (#2592) Aug 13, 2018
LICENSE Add CC0 license (#175) May 6, 2017
README.md Setup XPath compat data (#2287) Aug 27, 2018
index.d.ts Create TypeScript Definition File (#2308) Aug 20, 2018
index.js Setup XPath compat data (#2287) Aug 27, 2018
package-lock.json 55th alpha version Oct 18, 2018
package.json 55th alpha version Oct 18, 2018

README.md

mdn-browser-compat-data

https://github.com/mdn/browser-compat-data

This repository contains compatibility data for Web technologies. Browser compatibility data describes which platforms (where "platforms" are usually, but not always, web browsers) support particular Web APIs.

This data can be used in documentation, to build compatibility tables listing browser support for APIs. For example: Browser support for WebExtension APIs.

npm Build Status Twitter Follow

Maintained by the MDN team at Mozilla.

Installation

You can install mdn-browser-compat-data as a node package.

npm install mdn-browser-compat-data

Usage

const bcd = require('mdn-browser-compat-data');
bcd.css.properties.background;
// returns a compat data object (see schema)

Repository contents

There's a top-level directory for each broad area covered: for example, "http", "javascript", "webextensions". Inside each of these directories is one or more JSON file containing the compatibility data.

Please note that we have not (yet) migrated all compatibility data from the MDN wiki pages into this repository.

  • api/ contains data for each Web API interface.

  • css/ contains data for CSS properties, selectors, and at-rules.

  • html/ contains data for HTML elements, attributes, and global attributes.

  • http/ contains data for HTTP headers, statuses, and methods.

  • javascript/ contains data for JavaScript built-in Objects, statement, operators, and other ECMAScript language features.

  • mathml/ contains data for MathML elements, attributes, and global attributes.

  • svg/ contains data for SVG elements, attributes, and global attributes.

  • webdriver/ contains data for WebDriver commands.

  • webextensions/ contains data for WebExtensions JavaScript APIs and manifest keys.

  • xpath/ contains data for XPath axes, and functions.

  • xslt/ contains data for XSLT elements, attributes, and global attributes.

Format of the browser compat json files

The definitive description of the format used to represent compatibility data is the schema file. You can also have a look at the schema documentation.

Please note that we do not (yet) guarantee the stability of the data format. You're welcome to use the data, but its structure is subject to change without notice.

Issues?

If you find a problem, please file a bug.

Contributing

We're very happy to accept contributions to this data. Please familiarize yourself with the schema and send us a pull request. See also the Contributing file for more information.

Browser compatibility tables on MDN

It takes 1-2 weeks for changes in this data to be reflected in MDN's browser compatibility tables. The process is:

  1. A pull request is reviewed and merged to master.
  2. A new release of mdn-browser-compat-data is created by MDN staff. This happens every 4-14 days.
  3. A new image of Kumascript, which includes the BCD release, is built and deployed to production. This happens within a day of the npm package release.
  4. The MDN page using the data is regenerated. For newly converted pages, a staff member switches to the {{Compat}} macro, and re-checks the conversion. For updates to converted pages, a logged-in MDN user force-refreshes the page to regenerate it.

Projects using the data

Here are some projects using the data, as an npm module or directly: