Web Open Font Format
The Web Open Font Format (WOFF) is a font format for use in web pages. WOFF files are OpenType or TrueType fonts, with format-specific compression applied and additional XML metadata added. The two primary goals are to first distinguish font files intended for use as web fonts from fonts files intended for use in desktop applications via local installation, and second to reduce web font latency when fonts are transferred from a server to a client over a network connection.
Filename extension |
|
---|---|
Internet media type | |
Magic number | |
Developed by | W3C |
Type of format | Font file |
Container for | SFNT fonts |
Website |
Standardization
The first draft of WOFF 1 was published in 2009 by Jonathan Kew, Tal Leming, and Erik van Blokland,[3] with reference conversion code written by Jonathan Kew.[4] Following the submission of WOFF to the World Wide Web Consortium (W3C) by the Mozilla Foundation, Opera Software and Microsoft in April 2010,[5][6] the W3C commented that it expected WOFF to soon become the "single, interoperable [font] format" supported by all browsers.[7] The W3C published WOFF as a working draft in July 2010.[8][9] The final draft was published as a W3C Recommendation on 13 December 2012.[10]
WOFF 2.0, with reference code provided by Google,[11] has an improved compression scheme, using Brotli for byte-level compression, and became a W3C Recommendation in March 2018.[12]
Specification
WOFF is a wrapper containing SFNT-based fonts (TrueType or OpenType) that have been compressed using a WOFF-specific encoding tool so they can be embedded in a Web page.[13] WOFF Version 1 uses the widely available zlib compression (specifically, the compress2 function),[13] typically resulting in a file size reduction for TrueType files of over 40%.[14] Since OpenType CFF files (with PostScript glyph outlines) are already compressed, their reduction is typically smaller.[15]
Vendor support
Each version of the format has received the backing of many font vendors, also known as type foundries,[16] and has been supported by all major browsers:
- Firefox since version 3.6[17]
- Google Chrome since version 6.0[18]
- Internet Explorer since version 9[19]
- Konqueror since KDE 4.4.1[20]
- Microsoft Edge
- Opera since version 11.10[21] (Presto 2.7.81)[22]
- Safari[23] 5.1[24]
- other WebKit-based browsers since WebKit build 528[25][26]
WOFF 2.0, based on the Brotli compression algorithm and other improvements over WOFF 1.0 giving more than 30% reduction in file size, is supported in
- Google Chrome (since version 36),[27]
- Edge (since version 14),[28]
- Opera (since version 26),[29]
- Firefox (since version 35)[30]
- Safari (since version 10).[31]
Some browsers enforce a same-origin policy, preventing WOFF fonts from being used across different domains. This restriction is part of the CSS 3 Fonts module,[32] where it applies to all font formats and can be overridden by the server providing the font.
Some servers may require the manual addition of WOFF's MIME type to serve the files correctly.[33] Since February 2017, the proper MIME type is font/woff
for WOFF 1.0 and font/woff2
for WOFF 2.0[1][2]. Prior to February 2017, the standard MIME type for WOFF 1.0 was application/font-woff
, and some applications may still use the old type, though it is now deprecated.[1]
See also
References
- "Media Types". IANA. 2017-10-12. Retrieved 2017-10-17.
- "The "font" Top-Level Media Type". IETF. February 2017. RFC 8081. Retrieved 2017-10-17.
- Kew (Mozilla), Jonathan; Leming (Type Supply), Tal; van Blokland (LettError), Erik (2009-10-23), WOFF File Format (draft of 2009-10-23), Mozilla Foundation, retrieved 2010-01-30
- WOFF conversion reference code, retrieved May 8, 2016
- WOFF File Format 1.0 Submission Request to W3C
- Galineau, Sylvain (2010-04-23), Meet WOFF, The Standard Web Font Format, Microsoft
- Team Comment on "WOFF File Format 1.0" Submission
- WOFF - Now loading fonts on websites, The H, 2010-07-28
- Buckler, Craig (2010-08-17), W3C Backs the WOFF WebFont Standard, SitePoint
- "WOFF File Format 1.0". www.w3.org. Retrieved 2019-08-31.
- Reference WOFF2 generation code, retrieved May 8, 2016
- W3C: WOFF File Format 2.0
- Kew (Mozilla), Jonathan; Leming (Type Supply), Tal; van Blokland (LettError), Erik (2009-10-23), WOFF File Format (draft of 2009-10-23), Mozilla Foundation, retrieved 2010-01-30
- Stefanov, Stoyan (2009-10-20), @font-face gzipping - take II, PHPied.com, retrieved 2010-01-30
- http://blog.typekit.com/2010/12/08/type-rendering-font-outlines-and-file-formats/
- Wardle, Tiffany (2009-07-16), Typegirl - Most of the important foundries are supporting #webfont, tumblr, retrieved 2010-02-05
- Shapiro, Melissa (2009-10-20), Mozilla Supports Web Open Font Format, Mozilla Foundation, retrieved 2010-02-05
- Colyer, Matt (2010-09-21), Typekit adds Chrome 6 WOFF support, Typekit
- Hachamovitch, Dean (2010-06-23), HTML5, Native: Third IE9 Platform Preview Available for Developers, Microsoft
- KDE SVN Revision 1088984, KDE Bugzilla, 2010-02-12, retrieved 2011-10-14
- A first glimpse at Opera 11.10 "Barracuda", Opera Software, 2011-02-17, retrieved 2011-02-17
- Web specifications support in Opera Presto 2.7, Opera
- Safari Features, Apple, 2011-06-06, retrieved 2011-10-14
- Safari 5.1 Changelog, FileHippo.com, retrieved 2011-10-14
- Bug 38217 - [chromium] Add WOFF support, WebKit
- Bug 31302 - Add WOFF support for @font-face, WebKit
- Chromium 36 Release Notes, Google
- Speed up page load with WOFF 2.0 fonts in Microsoft Edge, Microsoft
- Opera 26 Release Notes, Opera Software ASA
- Firefox 35 Release Notes, Mozilla Developer Network
- What's new in Safari, Apple
- CSS Fonts Module Level 3
- "Webfonts are not loading in Firefox". Fontspring. Retrieved 2013-01-01.
External links
- Current specification of the WOFF 1.0 file format at the World Wide Web Consortium's website
- Current specification of the WOFF 2.0 file format at the World Wide Web Consortium's website