时间:2021-07-01 10:21:17 帮助过:3人阅读
jQuery.getScript("/path/to/myscript.js", function(data, status, jqxhr) {
/*
在脚本已载入并执行后,就可以做一些处理了
*/
});
getScript 方法返回一个 jqXHR 对象,因此可以这样使用:
代码如下:
jQuery.getScript("/path/to/myscript.js")
.done(function() {
/* 执行成功后的处理 */
})
.fail(function() {
/* 执行失败后的处理 */
});
使用 jQuery.getScript 的最常见场景是延迟加载一个插件,并在加载后调用它:
代码如下:
jQuery.getScript("jquery.cookie.js")
.done(function() {
jQuery.cookie("cookie_name", "value", { expires: 7 });
});
如果你需要做更高级的事情,如加载多个脚本和不同类型的文件(文本文件,图像,CSS 文件等),我建议你切换到一个功能更强大的 JavaScript 加载器。如果只想延迟加载插件,而不是简单地在每个页面加载的情况下,getScript 是完美的!
缓存问题
需要注意的是,当使用 jQuery.getScript 的时候,在脚本 URL 后面会自动被添加上时间戳,让脚本不缓存。因此你需要设置让所有的请求都缓存脚本:
代码如下:
jQuery.ajaxSetup({
cache: true
});
如果您不希望覆盖所有的缓存与你的 AJAX 请求,最好使用 jQuery.ajax 方法并把 dataType 设置为 script,例如这样:
代码如下:
jQuery.ajax({
url: "jquery.cookie.js",
dataType: "script",
cache: true
}).done(function() {
jQuery.cookie("cookie_name", "value", { expires: 7 });
});
在加载脚本的时候需要特别注意缓存问题!