У меня есть страница, которая содержит iframe
, которая загружается с использованием Javascript:
index.html
<iframe id="myFrame" width="800" height="600" style="display: none;"></iframe>
<div id="loader"><!-- some loading indicator --></div>
<script type="text/javascript">
function someFunction() {
var myFrame = document.getElementById('myFrame');
var loader = document.getElementById('loader');
loader.style.display = 'block';
myFrame.src = 'myFrame.html';
myFrame.onload = function() {
myFrame.style.display = 'block';
loader.style.display = 'none';
};
}
</script>
Страница, загружаемая в iframe
, содержит некоторую логику Javascript, которая вычисляет размеры определенных элементов для целей добавления управляемой JS полосы прокрутки (jScrollPane + jQuery Dimensions).
myFrame.html
<div id="scrollingElement" style="overflow: auto;">
<div id="several"></div>
<div id="child"></div>
<div id="elements"></div>
</div>
<script type="text/javascript">
$(document).load(function() {
$('#scrollingElement').jScrollPane();
});
</script>
Это работает в Chrome (и, возможно, в других браузерах Webkit), но не работает в Firefox и IE, потому что во время вызова jScrollPane
все элементы остаются невидимыми, и jQuery Dimensions не может определить размеры какого-либо элемента.
Есть ли способ убедиться, что мой iframe
виден до вызова $(document).ready(...)
? Кроме использования setTimeout
для задержки jScrollPane
, чего я определенно хочу избежать.