So, there is no performance hit with the following (as long as your CSS is reasonably sized), you get to leave the <link>
tag in <head>
, and it works without issue, but you are still basically 'reloading' your <link>
elements (though you are not doing so by resetting their url).
On the removal of the <iframe>
element, simply do the following:
var sheets = document.styleSheets;
for(var s = 0, slen = sheets.length; s < slen; s++) {
sheets[s].disabled = true;
sheets[s].disabled = false;
}
Reloading is all I can really think of as working since it seems to be removing it in garbage collection from the <iframe>
. Set up a test page that obviously only works for IE 8.
Of Note: I was originally unable to reprodcue this issue using Google web fonts, and had to specifically download a .eot
font for use for this. So your work around maybe to use WOFF fonts first, and only load EOT if necessary.
Not exactly sure if this is what you were looking for, but if it's not, please clarify and I'll edit as necessary.
Update 1: The cause
So, I've narrowed down the cause of the issue. I am only able to reproduce if the following occurs (and this is a nasty one folks).
- And
<iframe>
is contained within a parent element
- The parent element's class is changed
- The class does not change the
display
of the element it is being applied to (or really, if it does not change the overall display on the <iframe>
element)
And, from what I can tell, yes, it has to be the class name. I was unable to reproduce given the same steps on the id
of an element. Seriously. This one is a nasty one. I'll keep digging a bit.
Update 2: A Secondary Cause
If the <iframe>
is not fully in the browser window on draw, it will not load the font within the <iframe>
window, and will unload the font for the main window whenever it has to redraw the page (most notably when it is resized). This is a gnarly bug.
Update 3: What should be a solution
Instead of using display: none;
, set the height and the width of the element to be 0px
and the overflow: hidden;
, and you'll get the same effect as display none, but it will not remove it from the DOM, thereby not redrawing the page and taking your font. My test page from before has been updated, so you can see the effect on what used to be the bug.