queryLocalFonts

One of the larger downloads when requesting a webpage are custom fonts. There are many great techniques for lazy loading fonts to improve performance for those on poor connections. By getting insight into what fonts the user has available, we can avoid loading custom fonts. That’s where queryLocalFonts comes in — an native JavaScript function to gather user font information.

queryLocalFonts is an async function that requires user permission via a browser prompt when first executed. queryLocalFonts returns an array of FontData objects which contain information about all available fonts:

 const localFonts = await window.queryLocalFonts();  // [FontData, FontData, ...]  /* {   family: "Academy Engraved LET",   fullName: "Academy Engraved LET Plain:1.0",   postscriptName: "AcademyEngravedLetPlain",   style: "Plain", } */ 

If you’d like to target a specific font face, you can also directly query the postscriptName property:

 const canelaFonts = await window.queryLocalFonts({   postscriptNames: ["Canela", "Canela-Bold"], });  // [FontData, FontData, ...] 

With queryLocalFonts you can leverage a fonts a user already has instead of downloading expensive custom fonts. The prompt for permissions seems like it would deter users from allowing the API, however. It’s so cool that this API exists though!

The post queryLocalFonts appeared first on David Walsh Blog.

David Walsh Blog

Posted in: JavaScript

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.