Clientside script to detect woff2, woff, ttf or svg font support.
The detection method is selfcontained and exposed via UMD as a function that accepts a callback. It clocks in at 5.5kb minified and 2.8kb gzipped.
Note: eot detection has been left out on purpose as browser that would otherwise require eot fonts (<IE9) have either no support for datauris or very little (IE8 only supports 32kb) - making detection more or less useless.
fontSupport(callback /*, returnOption*/)
- callback [function]- Once the tests have been run this callback will be executed.
- returnOption [array|string|null]- Optional. A format string will return a boolean whether that format is supprted. An array of format strings will return the first listed supported format or null if none of them are supported. Default will return an object with formats as keys with boolean values.
With returnOption as null (default):
fontSupport(function (supported) {
	  if (supported.woff2) {
	    // woff2 is supported
	  }
	  if (supported.woff) {
	    // woff is supported
	  }
	  if (supported.ttf) {
	    // ttf is supported
	  }
	  if (supported.svg) {
	    // svg is supported
	  }
});With returnOption as string:
fontSupport(function (supported) {
	  if (supported) {
	    // ttf is supported
	  }
}, "ttf");With returnOption as an array:
fontSupport(function (supported) {
	switch (supported) {
		case "woff":
			// do stuff
			break;
		case "ttf":
			// do other stuff
			break;
	}
}, ["woff", "ttf"]);require(["font-support"], function (supported) {
  // see vanilla js usage
});Install dependencies:
npm install
Build script:
node build.js
The built index.js script will then be ready for use.
The basic template for testing was hoisted from the Modernizr library.
Uses svg2ttf and ttf2woff from Vitaly's brilliant collection of libraries.
Changes:
- Updated devDependencies.
Fixed:
- Added pre-generated WOFF2 file to avoid errors on manual builds.
Fixed:
- IE11 bug: @font-face failed OpenType embedding permission check. Permission must be Installable.via nodettfpatch.
- Subsequent calls to fontSupportdidn't execute callbacks.
- returnOptionof array now returned the wrong result.
Changes:
- WOFF2 now needs to be built manually; needs tooling to automate this :(
Changes:
- Removed grunt as dependency.
Features:
- woff2 added.