Skip to content
This repository

So here we're collecting all the shims, fallbacks, and polyfills in order to implant html5 functionality in browsers that don't natively support them.

The general idea is that: we, as developers, should be able to develop with the HTML5 apis, and scripts can create the methods and objects that should exist. Developing in this future-proof way means as users upgrade, your code doesn't have to change but users will move to the better, native experience cleanly.

Looking for a way to conditionally load these scripts client-side based on feature detects? See Modernizr. Looking for a guide to writing your own polyfills? See Writing Cross-Browser JavaScript Polyfills. Looking for a alphabetical guide on HTML5, CSS3, etc features and how you should use them? See HTML5PLEASE.

The No-Bullshit Guide to HTML5 Fallbacks

SVG

  • svgweb by Brad Neuberg & others
    • Fallback via Flash
  • Raphaël by Dmitry Baranovsky
    • Abstracted API. adds features. fallback for IE via VML
  • Ample SDK by Sergey Ilinsky
  • canvg by Gabe Lerner
    • Writes SVG to canvas. Good for Android
  • SVG Boilerplate
    • Alpha and still buggy, but handle multiple concurrent SVG shims together
  • SIE SVG library by dhrname
    • Fallback to VML for oldIE
  • dojo gfx by Eugene Lazutkin, Kun Xi, Chris Mitchell
    • Fallback via VML, Canvas, Silverlight and Flash
  • fabric.js by kangax
    • Can render SVG via canvas

SVG SMIL

Canvas

Web Storage (LocalStorage and SessionStorage)

Non HTML5 API Solutions

Sectioning Elements

  • html5shiv by afarkas, Jon Neal & community
    • Enables for print use, as well
  • innerShiv by Joe Bartlett
    • Enables elements for innerHTML use (deprecated, replaced by html5shiv)

Video

  • html5media
    • Uses flowplayer swf for fallback.
  • mediaelement.js by John Dyer
    • swf player that mimics HTML5 media API. Consistent UI across browsers and flash. <track> support.
  • SublimeVideo
    • World's first zero maintenance HTML5 video player as a service solution.
  • video.js by Zencoder
    • Device fixes. <track> support
  • LeanBack Player - HTML5 audio/video media player
    • HTML5 audio/video media player UI, easy to integrate and independent of other JS libraries.
  • video for everybody by Kroc Camen (orig.)
    • The granddaddy of <video> fallbacks. Markup-based solution, works without javascript. A must read.

VTT: Video Timed Track (subtitles)

  • videosub
  • JSCaptions by Daniel Davis
  • Captionator by Christopher Giffard (Supports WHATWG TextTrack spec & has experimental support for MediaTracks/synchronised media elements)
  • playr by Julien Villetorte (support both WebVTT & SubRip files)

Audio

  • SoundJS SoundJS provides a simple API and powerful features that abstract away the difficulties in varied browser audio support. Optional flash fallback for older browser support. Extensive documentation and active community.
  • audioJS AudioJS is a agnostic and cross-browser lib to work easily with the AudioContext API of HTML5.
  • jPlayer custom player with jQuery dependency, flash fallback
  • audio.js custom player, flash fallback by ab+c
  • SoundManager2 custom player, flash fallback, api, extensive documentation
  • LeanBack Player - HTML5 audio/video media player
    • HTML5 audio/video media player UI, easy to integrate and independent of other JS libraries.

New Events

  • transitionEnd Agnostic lib cross-browser to work with event transitionend.

IndexedDB

Web SQL Database

Local Database Abstractions (non-HTML5 APIs, but useful)

Web Forms

Web Forms : input placeholder

Accessibility / ARIA

Web Workers

Web Sockets

Geo-Location

Application Cache

Browser State Management

Offline & Online Events

HTML5 History API (pushState, replaceState, popState)

  • History.js by Benjamin Lupton - (optional hashchange fallback for HTML4 browsers)
  • HTML5-History-API by Dmitriy Pakhtinov - lightweight and fully standardize compliant implementation of History API with IE6+ support and hashchange implementation
  • * PJAX (pushState + ajax = pjax) by Chris Wanstrath (not a polyfill)

Hashchange Event

EventSource

Animated PNG (APNG)

  • APNG-Canvas by Давид Мзареулян
  • png.js by Devon Govett
    • Parses and renders PNGs both animated and static to a canvas element with putImageData

Ruby

<details> and <summary>

<meter>

Support for <output>, <progress>, <menu>, <command>, <keygen> elements..

dataset property (for use with custom data-* attributes)

<datalist>

<ol reversed>

<style scoped>

  • Scoped Styles by Simon Madine
    • jQuery Plugin to enable the scoped attribute on style blocks so they only affect their parent element's children.

<img srcset>

  • srcset plugin by Ian Culshaw
    • vanilla polyfill to support srcset for <img> tags where srcset is not supported. Doesn't run in supported browsers.

File API

  • dropfile.js by Andrew Dodson
    • Creates the FileReader part of the FileAPI via silverlight for drag and drop files
  • FileSaver.js by Eli Grey
    • Implements saveAs()
    • Includes BlobBuilder shim
  • mOxie Polyfill pulled out from Plupload
    • FileReader, drag and drop
    • XHR2 shim for storing on IE<10, FormData
    • Flash fallback
    • File input 'overlay'
  • FileReader.js by Jahdrien
    • Creates FileReader and FileAPI using Flash, jQuery and jQuery UI
    • No drag and drop support!
  • FileAPI by Konstantin Lebedev (© Mail.ru Group)
    • Multiupload: all browsers that support HTML5 or Flash
    • Drag'n'Drop upload: files (HTML5) & directories (Chrome 21+)
    • Upload one file: all browsers
    • Working with Images: IE6+, FF 3.6+, Chrome 10+, Opera 11.1+, Safari 5.4+
  • idb.filesystem.js by Eric Bidelman
    • HTML5 Filesystem API polyfill that uses IndexedDB as a storage layer.
  • window.saveAs by Andrew Dodson
    • Simple shim (for IE10 current Chrome and FireFox)

Binary and Typed data

Base64 (window.atob and window.btoa)

WebRTC/getUserMedia()

  • getUserMedia.js by Addy Osmani provides a cross-browser shim for getUserMedia() camera access.
  • webrtc4all by Doubango Telecom provides the WebRTC APIs for Safari, Opera and IE via an NPAPI/ActiveX plugin.

WebGL

MathML

(Web) Audio (Data) API

classList

Cross-Document/Domain Messaging (postMessage)

  • easyXDM by Sean Kinsey
    • Implements XDM and RPC in most browsers since IE6. Also ships with an endpoint for exposing ajax across the domain boundary.
  • postMessage jquery plugin by Ben Alman.

Cross-Origin Resource Sharing (CORS)

  • XDomain by Jaime Pillora
    • Transparently enable cross-domain XMLHttpRequest by adding a small proxy.html on the destination domain*
  • pmxdr by Eli Grey.
    • Implements a CORS-compliant cross-domain XMLHttpRequest with postMessage. Note that sites being requested must have a pmxdr host.
  • libxdr by Eli Grey.
    • Implements a CORS XMLHttpRequest drop-in using pmxdr.
  • postmessage-proxied-xhr (PPX) by Atul Varma.
  • flXHR by Kyle Simpson
    • Provides XHR API using Flash transport mechanism. Target server must have a crossdomain.xml policy file.

DOM

Pointer Events (API)

Pointer Events (CSS)

  • Pointer Events Polyfill by Kent Mewhort.
    • Implements pointer-events: none in IE and other non-supporting browsers.

DOM Range and Selection

DOM Parsing and Serialization

XPath

  • js-xpath provides document.evaluate/createNSResolver/createExpression and XPathResult/XPathNSResolver/XPathExpression support.
  • wicked-good-xpath rewrite of js-xpath with support for newer (>9) IE versions

Arrays

  • Array.prototype.slice adds ability to treat DOM elements as arrays. This behavior is not required by any standard given that it applies to host object behavior (which is implementation-dependent), but it is not forbidden either.
  • Array Generics - Implementation of standard Array methods (introduced in ECMAScript 5th edition) and shorthand generics (JavaScript 1.8.5) Browser support: Internet Explorer 6+, Firefox 1.5+, Chrome, Safari, Opera.

ECMAScript 5

ECMAScript 6 (Harmony)

CSS Prefix generators

  • cssFx - by Ivan Malopinsky
    • Standalone, lightweight, client-side JS; supports almost all CSS3 properties
  • CSS Crush
    • A PHP based CSS pre-processor for handling vendor prefixes, CSS variables, data-uris and minification
  • CSS Agent by Keith Clark
    • A ASP.Net based CSS pre-processor for handling vendor prefixes, CSS variables and minification
  • jQuery Css3 Finalize by Han Lin Yap
  • -prefix-free by Lea Verou
  • Autoprefixer by Andrey Sitnik
    • A fast post-processor that uses the data on current browser popularity (caniuse.com) and adds their vendor prefixes or other required syntax changes. Great integration with Grunt, Rails, Sublime Text, and others.

CSS, core modules

Selectors, L3-spec, L4-spec

  • selectivizr by Keith Clark
  • cssParentSelector by Kasper Mikiewicz
  • CSS3/4 querySelectorAll and matches polyfill by Егор Халимоненко. Pure JS with optional IE6/7 support. Currently CSS4 Selector API supporting:
    • subject of a selector: "div! a[href*=twitter]"
    • :scope pseudo-class: ":scope>*:nth-child(2n+1)"
    • nodesRef: document.querySelector("a", <div>) -> <a> child of <div>

Values and Units, spec

  • CSS3 - REM Unit conversion by Chuck Carpenter and Lucas Serven
    • Evaluates stylesheets for REM declarations, converts them to pixels and appends to the HEAD. Has no dependencies, but can easily be implemented with Modernizr/Yepnope for loading.
  • Units by Grady Kuhnline
    • Units is a JavaScript library for converting between angle and length units (including the 'rem' unit). Both are intended for use within other libraries that need to convert between acceptable CSS units when creating polyfills.
  • vminpoly by Sebastian Ferreyra
    • A polyfill for CSS units vw, vh & vmin.
  • Prefixfree - Viewport Relative Units Plugin by Lea Verou
    • Another vw, vh and vmin polyfill but requires prefixfree (2kb).
  • cssMinMax by Russ Porosky
    • min() and max() jQuery plugin polyfill
    • Includes JSCSSP, so it's a bit large

Image Values and Replaced Content, L3-spec, L4-spec

Backgrounds and Borders, spec

  • CSS3 PIE by Jason Johnston
    • CSS3 decoration rendering for IE 6-9. Supports: border-radius, box-shadow, multiple backgrounds, linear gradients, border-image
  • background-size polyfill by Louis-Rémi Babé
    • background-size for IE7 and IE8 via Microsoft's proprietary CSS behavior / .htc-script

Basic user interface, spec

  • jQuery Text Overflow plugin by Devon Govett, Andrew A. Kononykhin, Micky Hulse
  • borderBoxModel by Alberto Gasparin
    • box-sizing: border-box; javascript polyfill for IE6+
  • box-sizing-polyfill by Christian "Schepp" Schaefer
    • box-sizing: border-box; for IE6 and IE7 via Microsoft's proprietary CSS behavior / .htc-script
  • Borderbox for Compass by Richard Herrera
    • box-sizing: border-box; polyfill for SASS/Compass. Outputs equivalent CSS for IE6 & 7

CSS, responsive design modules

Media Queries, spec

  • css3-mediaqueries-js
  • Respond by Scott Jehl
    • A fast & lightweight polyfill for min/max-width CSS3 Media Queries (for IE 6-8, and more)
  • mediatizr by Aurélien Delogu
    • Responsive-oriented CSS3 media queries polyfill
  • matchMedia by Scott Jehl, Paul Irish, Nicholas Zakas
    • A standardized way to check media query matching in script.
  • jQuery Media Helpers by Scott Jehl
    • Some media query and cross-browser responsive design helpers, abstracted from jQuery Mobile
  • pointeraccuracy.js by n-fuse
    • Implementation of the 'pointer' media query

Conditional rules, spec

CSS, text modules

Text decoration, spec

CSS, font modules

Font events, spec

CSS, layout modules

Multi-column Layout, spec

Flexible Box Layout, spec

  • Flexie by Richard Herrera
    • Flexible box model - old spec from 2009. (flexbox) Supports: box-orient, box-align, box-direction, box-pack, box-flex, box-ordinal-group

Grid Layout, spec

Template Layout, spec

Regions, spec

CSS, effects modules

Transforms, spec

Filter Effects, spec

CSS, generated content

  • CSS Polyfills by philschatz
    • Implements many of the CSS selectors and rules defined in CSS3 Generated and Replaced Content Module and CSS3 Generated Content for Paged Media Module

Microdata API

  • microdatajs by Philip Jägenstedt
  • Microdata-JS by Егор Халимоненко
    • Pure JS (Extending Element.prototype with IE6+ support)

Notification API

XBL

<link rel="prefetch|prerender" ...

  • jiagra by Samy Kamkar
    • A psuedo-polyfill for preloading pages to browser cache

Flash

  • Mozilla Shumway
    • Flash VM and runtime written in JavaScript.
  • Google Swiffy
    • Webapp converts SWF to HTML+JS. Supports subset of SWF 8 and ActionScript 2.0, and webkit-only output.
  • Adobe Wallaby
    • Desktop app converts FLA to HTML+JS.
  • Gordon
    • Javascript that interprets SWFs live. Plays only SWF1 files completely, as well as most of the SWF2 features.

Visibility

  • Visibility.js by Andrey Sitnik
  • visibly.js by Addy Osmani
  • Page Visibility shim for jQuery by Mathias Bynens
    • The HTML5 Page Visibility API allows you to determine whether your web page is visible to the user, is hidden in background tab or is prerendering. visibility.js deals with vendor-prefixes and provides a fallback for browsers without this API by assuming the page is always visible. However, this is a wrapper more than a polyfill.

Web Performance

Hyphenation

  • hyphenator by Mathias Nater
    • CSS3 defines six properties and an at-rule that influence hyphenation. hyphenator is a JavaScript implementation with pattern files for many languages.

GamePad API

Media Fragments

  • xywh.js Polyfill that lets you crop images and videos simply by using specific x, y, w(idth), and h(eight) parameters from their URIs. The library implements the spatial media fragments dimension of the W3C Media Fragments URI specification.
  • mediafragments.js Polyfill that lets you place deep links into videos and audios simply by using a specific t(ime) parameter from their URIs. The library implements the temporal media fragments dimension of the W3C Media Fragments URI specification.

Other

Mixed!

  • Webshims Lib several Polyfills using lightweight capability based loading concept (shiv, innershiv, canvas, forms, ES5, localStorage/sessionStorage, JSON, geolocation) by Alexander Farkas
  • Assorted file formats decoding of several file formats done in javascript, documented on the excellent jswiki
  • Polyfill.js Polyfills loaded dynamically based on need (list of available polyfills on the linked page) by James Brumond
  • ES5/DOM shim implements DOM API and EcmaScript 5 (and some from ES6), and bug fixing in IE6+ and other browsers:
    • Add methods such [add/remove]EventListener, querySelector[All], setSelectionRange, etc in IE6+
    • Add Element/Node properties such classList, children, [first/last]ElementChild, reversed, control, labels, etc in IE6+
    • Add methods such insertAdjacentHTML (old FF), stopImmediatePropagation (Opera < 12) and properties reversed, control, labels, etc in W3C browsers
    • Add ES5/6 methods in all browsers
    • Add DOM4 methods append, prepend, after, before, replace, remove, match in all browsers
    • Provide bugs fixing for DOM and ES in IE, Opera, Chrome, FF
    • and more with low cost (~8KiB for W3C browsers, ~16KiB for IE8 and ~18KiB for IE6/7 [gzip])

Everything!

  • console-polyfill by Paul Miller. Adds no-operation console methods to environments where console is not available. Basically makes console safe to use.
  • ie7.js, ie8.js, ie9.js by Dean Edwards
    • A JavaScript library to make MSIE behave like a modern browser. Many fixes including PNG transparency, CSS styles/selectors, rendering bug fixes, etc.
  • CSS3PIE

Contributors

Edited and maintained by Paul Irish. Contributions from Jonathan Cook, Mark Boas, Michael Behan, Mathias Bynens, Eli Grey, Øyvind Sean Kinsey, and others.

Something went wrong with that request. Please try again.