Как динамически загружать jquery и jquery-ui во внешний скрипт - PullRequest
0 голосов
/ 21 декабря 2018

Очень неопытный javascript / jquery / AJAX здесь;Я попытался, вероятно, два десятка подходов, чтобы сделать эту работу, и я в полном недоумении.

Я разработал виджет js и загружаю jquery, если его нет.Насколько я могу судить, это работает хорошо.К сожалению, как часть основной функции, я использую некоторые функции из jquery.ui.

Я знаю, что сначала мне нужно загрузить jquery, но как я могу расширить приведенный ниже скрипт, чтобы также загрузить jquery.ui, еслиего нет?

Любая помощь будет принята с благодарностью.

(function() {

// Localize jQuery variable
var jQuery;

/******** Load jQuery if not present *********/
if (window.jQuery === undefined || window.jQuery.fn.jquery !== '3.3.1') {
    var script_tag = document.createElement('script');
    script_tag.setAttribute("type","text/javascript");
    script_tag.setAttribute("src",
        "https://ajax.googleapis.com/ajax/libs/jquery/3.3.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();
}

/******** 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() { 
//main functionality here
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...