Итак, я пытаюсь создать встраиваемый виджет, который будет хорошо играть с другими, когда он будет загружен на внешний веб-сайт. Поскольку я никогда не делал этого, прежде чем я следовал отличному учебному пособию Алекса Марандона по телефону how to build a web widget. Я могу загрузить jquery (1.7.1), однако, когда я пытаюсь загрузить jquery-ui (1.8.16) - из w/в JS - я получаю JS-ошибку, в которой говорится, что «a не определено». Следующий скрипку воспроизводит то, что я вижу:Невозможно загрузить jquery-ui динамически - a не определено
http://jsfiddle.net/malonso/qfBLx/
Теперь, если я объединить JQuery и jqueryui в один файл и поместить его на мой сервер работает нормально, но это меньше, чем оптимальные по целому ряду причин и я хотел бы избежать этого, если это возможно. Другая странная вещь: если я пытаюсь загрузить любой другой JS-файл вместо jqueryui, файл загружается просто отлично; ясно, что там что-то не хватает.
Заранее спасибо.
Update:
скрипку содержат всю необходимую коду, но я буду включать яваскрипту часть ниже. Код ждет, пока браузер не загрузит jquery, а затем он сделает запрос на загрузку jqueryui. Я фактически использую jquery для печати отладочных операторов до и после запроса на загрузку jqueryui, поэтому jquery определенно «доступен». Только для хихиканья я пытался отложить загрузку jqueryui до 3 секунд после того, как браузер определит, что jquery загружен, и я получаю ту же проблему.
(function() {
// Localize jQuery variable
var jQuery;
/******** Load jQuery if not present *********/
if (window.jQuery === undefined || window.jQuery.fn.jquery !== '1.7.1') {
var script_tag = document.createElement('script');
script_tag.setAttribute("type","text/javascript");
script_tag.setAttribute("src","http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js");
if (script_tag.readyState) {
script_tag.onreadystatechange = function() { // For old versions of IE
if (this.readyState == 'complete' || this.readyState == 'loaded') {
scriptLoadHandler();
}
};
} else {
script_tag.onload = scriptLoadHandler;
}
// Try to find the head, otherwise default to the documentElement
(document.getElementsByTagName("head")[0] || document.documentElement).appendChild(script_tag);
} else {
// The jQuery version on the window is the one we want to use
jQuery = window.jQuery;
main();
}
/******** Called once jQuery has loaded ******/
function scriptLoadHandler() {
// Restore $ and window.jQuery to their previous values and store the
// new jQuery in our local jQuery variable
jQuery = window.jQuery.noConflict(true);
// Call our main function
main();
}
/******** Our main function ********/
function main() {
jQuery(document).ready(function($) {
loadJS();
});
}
function loadJS(){
jQuery('#debug').append("About to load jquery-ui<br>");
var script_tag = document.createElement('script');
script_tag.setAttribute("type","text/javascript");
script_tag.setAttribute("src","http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/jquery-ui.min.js");
(document.getElementsByTagName("head")[0] || document.documentElement).appendChild(script_tag);
jQuery('#debug').append("Request made to load jquery-ui<br>");
}
})(); // We call our anonymous function immediately
Спасибо Том, я ценю быстрый ответ. Я бы не согласился с тем, что это не имеет отношения к проблеме. Проблема в том, что загрузка jqueryui * вызывает * ошибку. Я даже не пытаюсь сделать что-либо в коде, который я прикреплял, а не просто загружать его. – malonso