现在在 GitHub 上:https : //github.com/patrickmarabeas/jQuery-FontSpy.js
本质上,该方法通过比较两种不同字体中字符串的宽度来工作。我们使用 Comic Sans 作为测试字体,因为它是最不同的网络安全字体,希望与您将使用的任何自定义字体有足够的不同。此外,我们使用了非常大的字体大小,因此即使是很小的差异也会很明显。计算 Comic Sans 字符串的宽度后,字体系列将更改为您的自定义字体,并回退到 Comic Sans。勾选时,如果字符串元素宽度相同,则仍然使用Comic Sans的fallback字体。如果没有,您的字体应该是可操作的。
我将字体加载检测的方法改写为一个 jQuery 插件,旨在让开发人员能够根据字体是否已加载来设置元素样式。添加了故障安全计时器,因此如果自定义字体无法加载,用户不会没有内容。这只是糟糕的可用性。
我还通过包含类的添加和删除,对字体加载期间和失败时发生的事情进行了更好的控制。您现在可以对字体执行任何您喜欢的操作。我只建议修改字体大小、行距等,以使您的回退字体尽可能接近自定义,这样您的布局保持完整,并且用户获得预期的体验。
这是一个演示:http : //patrickmarabeas.github.io/jQuery-FontSpy.js
将以下内容放入 .js 文件并引用它。
(function($) {
$.fontSpy = function( element, conf ) {
var $element = $(element);
var defaults = {
font: $element.css("font-family"),
onLoad: '',
onFail: '',
testFont: 'Comic Sans MS',
testString: 'QW@HhsXJ',
delay: 50,
timeOut: 2500
};
var config = $.extend( defaults, conf );
var tester = document.createElement('span');
tester.style.position = 'absolute';
tester.style.top = '-9999px';
tester.style.left = '-9999px';
tester.style.visibility = 'hidden';
tester.style.fontFamily = config.testFont;
tester.style.fontSize = '250px';
tester.innerHTML = config.testString;
document.body.appendChild(tester);
var fallbackFontWidth = tester.offsetWidth;
tester.style.fontFamily = config.font + ',' + config.testFont;
function checkFont() {
var loadedFontWidth = tester.offsetWidth;
if (fallbackFontWidth === loadedFontWidth){
if(config.timeOut < 0) {
$element.removeClass(config.onLoad);
$element.addClass(config.onFail);
console.log('failure');
}
else {
$element.addClass(config.onLoad);
setTimeout(checkFont, config.delay);
config.timeOut = config.timeOut - config.delay;
}
}
else {
$element.removeClass(config.onLoad);
}
}
checkFont();
};
$.fn.fontSpy = function(config) {
return this.each(function() {
if (undefined == $(this).data('fontSpy')) {
var plugin = new $.fontSpy(this, config);
$(this).data('fontSpy', plugin);
}
});
};
})(jQuery);
将其应用于您的项目
.bannerTextChecked {
font-family: "Lobster";
/* don't specify fallback font here, do this in onFail class */
}
$(document).ready(function() {
$('.bannerTextChecked').fontSpy({
onLoad: 'hideMe',
onFail: 'fontFail anotherClass'
});
});
移除那个 FOUC!
.hideMe {
visibility: hidden !important;
}
.fontFail {
visibility: visible !important;
/* fall back font */
/* necessary styling so fallback font doesn't break your layout */
}
编辑:FontAwesome 兼容性已被删除,因为它无法正常工作并遇到不同版本的问题。可以在这里找到一个 hacky 修复:https : //github.com/patrickmarabeas/jQuery-FontFaceSpy.js/issues/1