Как внедрить JQuery и использовать его в той же букмарклет? - PullRequest
0 голосов
/ 20 октября 2019

Я могу успешно внедрить jQuery на страницу со следующим букмарклетом:

javascript: void((function(doc) {
    if (typeof jQuery == 'undefined') {
        var script_jQuery = document.createElement('script');
        script_jQuery.setAttribute('src', 'https://code.jquery.com/jquery-latest.min.js');
        Node.prototype.appendChild.call(document.body, script_jQuery);
        console.log('jQuery included ^_^');
    } else {
        console.log('jQuery already included ...');
    }
})(document));

Есть ли способ использовать только что внедренный jQuery в том же букмаркете? Я попытался поставить console.log(jQuery.toString()) после части apend, но это не сработало. Мне кажется, что jQuery доступен для использования только после завершения работы букмарклета.

1 Ответ

1 голос
/ 20 октября 2019

Используйте onload обратный вызов нового элемента скрипта для инициализации вашего собственного кода jQuery

(function(doc) {

  function doStuff() {
    console.log('jQuery version ', $.fn.jquery, ' loaded')
    $('h1').text('Updated Title').css('color', 'red');
  }

  if (typeof jQuery == 'undefined') {
    var script_jQuery = document.createElement('script');
    script_jQuery.src = 'https://code.jquery.com/jquery-latest.min.js';

    // call doStuff() after jQuery.js loads
    script_jQuery.onload = doStuff;

    doc.body.appendChild(script_jQuery);
    console.log('script_jQuery appended to body');
    
  } else {
    console.log('jQuery already included ...');
    // initialize your code using existing version
    doStuff();
  }
})(document)
<h1>Blank</h1>
...