🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# jQuery ajax - getScript() 方法 ## 实例 通过 AJAX 请求来获得并运行一个 JavaScript 文件: ``` $("button").click(function(){ $.getScript("demo_ajax_script.js"); }); ``` ## 定义和用法 getScript() 方法通过 HTTP GET 请求载入并执行 JavaScript 文件。 ### 语法 ``` jQuery.getScript(_url_,_success(response,status)_) ``` | 参数 | 描述 | | --- | --- | | _url_ | 将要请求的 URL 字符串。 | | _success(response,status)_ | 可选。规定请求成功后执行的回调函数。额外的参数: _response_ - 包含来自请求的结果数据 _status_ - 包含请求的状态("success", "notmodified", "error", "timeout" 或 "parsererror") | ### 详细说明 该函数是简写的 Ajax 函数,等价于: ``` $.ajax({ url: _url_, dataType: "script", success: _success_ }); ``` 这里的回调函数会传入返回的 JavaScript 文件。这通常不怎么有用,因为那时脚本已经运行了。 载入的脚本在全局环境中执行,因此能够引用其他变量,并使用 jQuery 函数。 比如加载一个 test.js 文件,里边包含下面这段代码: ``` $(".result").html("<p>Lorem ipsum dolor sit amet.</p>"); ``` 通过引用该文件名,就可以载入并运行这段脚本: ``` $.getScript("ajax/test.js", function() { alert("Load was performed."); }); ``` 注释:jQuery 1.2 版本之前,getScript 只能调用同域 JS 文件。 1.2中,您可以跨域调用 JavaScript 文件。注意:Safari 2 或更早的版本不能在全局作用域中同步执行脚本。如果通过 getScript 加入脚本,请加入延时函数。 ## 更多实例 ### 例子 1 加载并执行 test.js: ``` $.getScript("test.js"); ``` ### 例子 2 加载并执行 test.js ,成功后显示信息: ``` $.getScript("test.js", function(){ alert("Script loaded and executed."); }); ``` ### 例子 3 载入 [jQuery 官方颜色动画插件](http://jquery.com/plugins/project/color "http://jquery.com/plugins/project/color") 成功后绑定颜色变化动画: HTML 代码: ``` <button id="go">Run</button> <div class="block"></div> ``` jQuery 代码: ``` jQuery.getScript("http://dev.jquery.com/view/trunk/plugins/color/jquery.color.js", function(){ $("#go").click(function(){ $(".block").animate( { backgroundColor: 'pink' }, 1000) .animate( { backgroundColor: 'blue' }, 1000); }); }); ```