Это на самом деле то, что я сделал.
Чтобы обеспечить загрузку определенного файла CSS, я добавил стиль в конец файла CSS. Например:
#ensure-cssload-8473649 {
display: none
}
Теперь у меня есть функция JavaScript, которая запускает обратный вызов, указанный при загрузке вышеуказанного стиля на страницу:
var onCssLoad = function (options, callback) {
var body = $("body");
var div = document.createElement(constants.TAG_DIV);
for (var key in options) {
if (options.hasOwnProperty(key)) {
if (key.toLowerCase() === "css") {
continue;
}
div[key] = options[key];
}
}
var css = options.css;
if (css) {
body.appendChild(div);
var handle = -1;
handle = window.setInterval(function () {
var match = true;
for (var key in css) {
if (css.hasOwnProperty(key)) {
match = match && utils.getStyle(div, key) === css[key];
}
}
if (match === true) {
window.clearTimeout(handle);
body.removeChild(div);
callback();
}
}, 100);
}
}
И вот как я использовал вышеописанную функцию:
onCssLoad({
"id": "ensure-cssload-8473649",
css: {
display: "none"
}
}, function () {
// code when you want to execute
// after your CSS file is loaded
});
Здесь 1-й параметр принимает options
, где id
- это проверка на соответствие тесту стиля и свойство css для проверки того, что загружено из CSS.