Need help with Modernizr?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

24.6K Stars 3.0K Forks Other 2.6K Commits 176 Opened issues


Modernizr is a JavaScript library that detects HTML5 and CSS3 features in the user’s browser.

Services available


Need anything else?

Contributors list


npm version Build Status Build Status codecov Inline docs

  • Read this file in Portuguese-BR here
Modernizr is a JavaScript library that detects HTML5 and CSS3 features in the user’s browser.

Modernizr tests which native CSS3 and HTML5 features are available in the current UA and makes the results available to you in two ways: as properties on a global

object, and as classes on the
 element. This information allows you to progressively enhance your pages with a granular level of control over the experience.

Breaking changes with v4

  • Dropped Node 8 Support, please upgrade to Node v10

  • These tests got removed:

    • touchevents
      : discussion
    • unicode
      : discussion
    • templatestrings
      : duplicate of the es6 detect
    • contains
      : duplicate of the es6 detect
    • datalistelem
      : A dupe of Modernizr.input.list

New Asynchronous Event Listeners

Often times people want to know when an asynchronous test is done so they can allow their application to react to it. In the past, you've had to rely on watching properties or

 classes. Only events on asynchronous tests are
supported. Synchronous tests should be handled synchronously to improve speed and to maintain consistency.

The new API looks like this:

// Listen to a test, give it a callback
Modernizr.on('testname', function( result ) {
  if (result) {
    console.log('The test passed!');
  else {
    console.log('The test failed!');

We guarantee that we'll only invoke your function once (per time that you call

). We are currently not exposing a method for exposing the
functionality. Instead, if you'd like to have control over async tests, use the
feature, and any test that you set will automatically expose and trigger the

Getting Started

  • Clone or download the repository
  • Install project dependencies with
    npm install

Building Modernizr

From javascript

Modernizr can be used programmatically via npm:

var modernizr = require("modernizr");


method is exposed for generating custom Modernizr builds. Example:
var modernizr = require("modernizr");{}, function (result) { console.log(result); // the build });

The first parameter takes a JSON object of options and feature-detects to include. See

for all available options.

The second parameter is a function invoked on task completion.

From the command-line

We also provide a command line interface for building modernizr. To see all available options run:


Or to generate everything in 'config-all.json' run this with npm:

npm start
//outputs to ./dist/modernizr-build.js

Testing Modernizr

To execute the tests using mocha-headless-chrome on the console run:

npm test

You can also run tests in the browser of your choice with this command:

npm run serve-gh-pages

and navigating to these two URLs:


Code of Conduct

This project adheres to the Open Code of Conduct. By participating, you are expected to honor this code.


MIT License

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.