Я усвідомлюю, що тут трохи запізнююся (на 5 років чи більше), але, думаю, є краща відповідь, ніж прийнята, наступним чином:
$("#addComment").click(function() {
if(typeof TinyMCE === "undefined") {
$.ajax({
url: "tinymce.js",
dataType: "script",
cache: true,
success: function() {
TinyMCE.init();
}
});
}
});
getScript()
Функція фактично запобігає кешування в браузері . Якщо ви запустите трасування, ви побачите, що сценарій завантажений URL-адресою, що містить параметр часової позначки:
http://www.yoursite.com/js/tinymce.js?_=1399055841840
Якщо користувач натискає #addComment
посилання кілька разів,tinymce.js
він буде повторно завантажений з іншої URL-адреси, що позначається часом. Це перемагає мету кешування браузера.
===
Крім того, в getScript()
документації є деякий зразок коду, який демонструє, як увімкнути кешування, створивши власну cachedScript()
функцію наступним чином:
jQuery.cachedScript = function( url, options ) {
// Allow user to set any option except for dataType, cache, and url
options = $.extend( options || {}, {
dataType: "script",
cache: true,
url: url
});
// Use $.ajax() since it is more flexible than $.getScript
// Return the jqXHR object so we can chain callbacks
return jQuery.ajax( options );
};
// Usage
$.cachedScript( "ajax/test.js" ).done(function( script, textStatus ) {
console.log( textStatus );
});
===
Або, якщо ви хочете глобально відключити кешування, ви можете зробити це, використовуючи ajaxSetup()
наступне:
$.ajaxSetup({
cache: true
});