jQuery ajax - getScript() 方法和getJSON方法
实例
使用 AJAX 请求来获得 JSON 数据,并输出结果:
$("button").click(function(){ $.getJSON("demo_ajax_json.js",function(result){ $.each(result, function(i, field){ $("p").append(field + " "); }); }); });
定义和用法
通过 HTTP GET 请求载入 JSON 数据。
在 jQuery 1.2 中,您可以通过使用 JSONP 形式的回调函数来加载其他网域的 JSON 数据,如 "myurl?callback=?"。jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。 注意:此行以后的代码将在这个回调函数执行前执行。
语法
jQuery.getJSON(url,data,success(data,status,xhr))
参数 | 描述 |
---|---|
url | 必需。规定将请求发送的哪个 URL。 |
data | 可选。规定连同请求发送到服务器的数据。 |
success(data,status,xhr) |
可选。规定当请求成功时运行的函数。 额外的参数:
|
详细说明
该函数是简写的 Ajax 函数,等价于:
$.ajax({ url: url, data: data, success: callback, dataType: json });
发送到服务器的数据可作为查询字符串附加到 URL 之后。如果 data 参数的值是对象(映射),那么在附加到 URL 之前将转换为字符串,并进行 URL 编码。
传递给 callback 的返回数据,可以是 JavaScript 对象,或以 JSON 结构定义的数组,并使用 $.parseJSON() 方法进行解析。
示例
从 test.js 载入 JSON 数据并显示 JSON 数据中一个 name 字段数据:
$.getJSON("test.js", function(json){ alert("JSON Data: " + json.users[3].name); });
例子 1
从 Flickr JSONP API 载入 4 张最新的关于猫的图片:
HTML 代码:
<p id="images"></p>
jQuery 代码:
$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne? tags=cat&tagmode=any&format=json&jsoncallback=?", function(data){ $.each(data.items, function(i,item){ $("<img/>").attr("src", item.media.m).appendTo("#images"); if ( i == 3 ) return false; }); });
例子 2
从 test.js 载入 JSON 数据,附加参数,显示 JSON 数据中一个 name 字段数据:
$.getJSON("test.js", { name: "John", time: "2pm" }, function(json){ alert("JSON Data: " + json.users[3].name); });
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) |
可选。规定请求成功后执行的回调函数。 额外的参数:
|
详细说明
该函数是简写的 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 官方颜色动画插件 成功后绑定颜色变化动画:
HTML 代码:
<button id="go">Run</button> <p class="block"></p>
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); }); });
以上就是jQuery ajax - getScript() 方法和getJSON方法的详细内容,更多请关注其它相关文章!
推荐阅读
-
jQuery插件jqGrid动态获取列和列字段的方法
-
jquery通过ajax加载一段文本内容的方法教程
-
jQuery避免$符和其他JS库冲突的方法对比
-
jquery的clone方法教程应用于textarea和select的bug修复
-
jquery中each方法教程示例和常用选择器
-
jQuery中ajax - post() 方法实例详解
-
Jquery中ajax提交表单几种方法(get、post两种方法)
-
jQuery中ajax - get() 方法实例详解
-
django中使用jquery ajax post数据出现403错误的解决办法(两种方法)
-
Jquery遍历的next()方法和prev()方法的使用讲解