Zdarzenie załadowane przez przeglądarkę internetową między przeglądarkami
Usiłuję zmierzyć szerokość określonego znaku z webfontu. Aktywne wydarzenie dostarczane przez GoogleWebfont Loader wystrzeliwuje nieco za wcześnie i pomiar dokonany na domyślnej czcionce.
Skrócona wersja skryptu, z którym pracuję:
window.WebFontConfig = {
google: {
families: ['Anonymous Pro:400,400italic,700,700italic']
},
active: function () {
$.fn.ready(MeasureM);
}
};
function MeasureM() {
var e = document.getElementById('div');
e.style.font = "15px/15px 'Anonymous Pro'";
e.appendChild(document.createTextNode('M'));
console.log(e.offsetWidth, e.offsetHeight);
}
(function () {
var wf = document.createElement('script');
wf.src = ('https:' == document.location.protocol ? 'https' : 'http') +
'://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js';
wf.type = 'text/javascript';
wf.async = 'true';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(wf, s);
})();
Element HTML:
<div id="div" style="display: table;"></div>
Dla wygody ajsFiddle.
Problem, który pojawia się tylko w Firefoksie, czy istnieje rozwiązanie? Czy jest coś, co nie rozumiem?