я столкнулся ошибка с загрузкой Bootstrap
библиотеки, как это всегда дает эту ошибку:Bootstrap требует JQuery Хотя Jquery уже загружен
Uncaught Error: Bootstrap's JavaScript requires jQuery
Несмотря на то что я крепление Bootstrap
библиотеки после убедившись, jQuery
загружен, но все еще получает ошибку.
Я использую следующий код, чтобы прикрепить jQuery
на страницу, создав элемент и добавить его в document
:
/******** Load jQuery if not present *********/
if (window.jQuery === undefined || window.jQuery.fn.jquery !== '3.1.1') {
console.log("jQuery LOADED");
var script_tag = document.createElement('script');
script_tag.setAttribute("type", "text/javascript");
script_tag.setAttribute("src",
"http://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js");
// Try to find the head, otherwise default to the documentElement
(document.getElementsByTagName("head")[0] || document.documentElement).appendChild(script_tag);
if (script_tag.readyState) {
script_tag.onreadystatechange = function() { // For old versions of IE
if (this.readyState == 'complete' || this.readyState == 'loaded') {
console.log(window.jQuery.fn.jquery);
scriptLoadHandler();
}
};
} else {
console.log("ONLOAD STATE");
script_tag.onload = scriptLoadHandler;
}
} else {
// The jQuery version on the window is the one we want to use
jQuery = window.jQuery;
main();
}
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();
}
Здесь Я создаю Bootstrap
после document
в готовности:
function main() {
jQuery(document).ready(function ($) {
var bootstrap_script = document.createElement('script');
bootstrap_script.setAttribute("type", "text/javascript");
bootstrap_script.setAttribute("src",
"https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js");
(document.getElementsByTagName("head")[0] || document.documentElement).appendChild(bootstrap_script);
})
}
Просто чтобы прояснить критическую вещь я пишу js
код в отдельном файле js
, потому что я хочу, чтобы использовать позже как jQuery plugin
. Таким образом, я пытаюсь прикрепить библиотеки, поскольку я не гарантирую, что целевая страница будет включать эти библиотеки или нет.
«JavaScript для Bootstrap требует jQuery версии 1.9.1 или новее, но ниже версии 4», но похоже, что это не проблема с jquery-версией, которая помещает ваш jquery перед этой функцией, если еще не выполнен. – Curiousdev
@Curiousdev Я уже поставил jQuery перед этой функцией –