Я понимаю, что немного опоздал (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
});