JQuery код после не выполнено
Я попытался загрузить с помощью jquery некоторые сценарии, и после завершения загрузки я хочу выполнить некоторый код.
Я ожидал получить alert(1)
называется, но ничего не происходит. Скрипты правильно загружены (проверено в console
).
$.when(
$.getScript ("/framework/static/libs/ckeditor/ckeditor/ckeditor.js"),
$.getScript ("/framework/static/libs/ckeditor/ckeditor/config.js"),
$.getScript ("/framework/static/libs/ckeditor/ckeditor/skins/bootstrapck/editor_gecko.css"),
$.getScript ("/framework/static/libs/ckeditor/ckeditor/lang/de.js"),
$.getScript ("/framework/static/libs/ckeditor/ckeditor/adapters/jquery.js"),
$.Deferred(function( deferred ){$( deferred.resolve );})
).done(function() {
alert (1);
});
Спасибо за вашу помощь.
1 ответ
Решение
Я надеюсь, что проблема в следующей строке.
$.getScript ("/framework/static/libs/ckeditor/ckeditor/skins/bootstrapck/editor_gecko.css")
Как вы можете найти в документации, он загружает файл JavaScript с сервера, используя HTTP-запрос GET, а затем выполняет его.
Для файлов CSS вы должны использовать код ниже.
window.getStyle = function(file) {
var top = $('head > link[rel=stylesheet]').length ? $('head > link[rel=stylesheet]:last') : $('head > *:last');
top.after('<link rel="stylesheet" type="text/css" href="' + file + '">');
};
$.when(
$.getScript("/framework/static/libs/ckeditor/ckeditor/ckeditor.js"),
$.getScript("/framework/static/libs/ckeditor/ckeditor/config.js"), window.getStyle("/framework/static/libs/ckeditor/ckeditor/skins/bootstrapck/editor_gecko.css"),
$.getScript("/framework/static/libs/ckeditor/ckeditor/lang/de.js"),
$.getScript("/framework/static/libs/ckeditor/ckeditor/adapters/jquery.js"),
$.Deferred(function(deferred) {
$(deferred.resolve);
})
).done(function() {
alert(1);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>