在这里,我们将给大家分享关于JQuery中使用$.ajax和$.getJSON方法获取JSON格式数据的知识,同时也会涉及到如何更有效地ajax获取json格式数据、jQueryajax-getJSO
在这里,我们将给大家分享关于JQuery中使用$.ajax和$.getJSON方法获取JSON格式数据的知识,同时也会涉及到如何更有效地ajax获取json格式数据、jQuery ajax - getJSON() 方法、jQuery ajax - getScript() 方法和getJSON方法、Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据的内容。
本文目录一览:- JQuery中使用$.ajax和$.getJSON方法获取JSON格式数据
- ajax获取json格式数据
- jQuery ajax - getJSON() 方法
- jQuery ajax - getScript() 方法和getJSON方法
- Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据
JQuery中使用$.ajax和$.getJSON方法获取JSON格式数据
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。JSONM文件中包含了关于“名称”和“值”的信息。有时候我们需要读取JSON格式的数据文件,在jQuery中可以使用Ajax或者 $.getJSON()方法实现。
下面就使用jQuery读取music.txt文件中的JSON数据格式信息。
首先,music.txt中的内容如下:
[
{"optionKey":"1", "optionValue":"Canon in D"},
{"optionKey":"2", "optionValue":"Wind Song"},
{"optionKey":"3", "optionValue":"Wings"}
]
接下来是HTML代码:
<div>点击按钮获取JSON数据</div>
<input type="button" id="button" value="确定" />
<div id="result"></div>
使用Ajax获取JSON数据的jQuery代码:
$(document).ready(function(){
$(''#button'').click(function(){
$.ajax({
type:"GET",
url:"music.txt",
dataType:"json",
success:function(data){
var music="<ul>";
//i表示在data中的索引位置,n表示包含的信息的对象
$.each(data,function(i,n){
//获取对象中属性为optionsValue的值
music+="<li>"+n["optionValue"]+"</li>";
});
music+="</ul>";
$(''#result'').append(music);
}
});
return false;
});
});
当然,也可以使用$.getJSON()方法,代码简洁一点:
$(document).ready(function(){
$(''#button'').click(function(){
$.getJSON(''music.txt'',function(data){
var music="<ul>";
$.each(data,function(i,n){
music+="<li>"+n["optionValue"]+"</li>";
});
music+="</ul>";
$(''#result'').append(music);
});
return false;
});
});
ajax获取json格式数据
$("#readerId").blur(function(){ var readerId=$("#readerId").val(); $.ajax({ type:"post",url:"<%=request.getcontextpath()%>/selectReadersById1.action",data:{"readerId":readerId},dataType:"text",success:function(data) { var myobj=eval(data); //for(var i=0;i<myobj.length;i++){ $("#readerName").val(myobj[0].name); $("#borrowNum").val(myobj[0].maxnum); $("#yajin").val(myobj[0].keepMoney); //} } }) })jQuery ajax - getJSON() 方法
通过 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
("url", { name: "John" }, function(json){
alert("JSON Data: " + json.users[3].name);
});
修改自http://www.w3school.com.cn/jquery/ajax_getjson.asp
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></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 alt="jQuery ajax - getScript() 方法和getJSON方法" >").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); });
<h1>jQuery ajax - getScript() 方法</h1><p><br></p><h2>实例</h2><p>通过 AJAX 请求来获得并运行一个 JavaScript 文件:</p><pre>$("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 代码:
<p></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方法的详细内容,更多请关注php中文网其它相关文章!
Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据
一、AjaxJson.aspx处理业务数据,产生JSon数据,供JqueryRequest.aspx调用,代码如下:
protected void Page_Load(object sender,EventArgs e)
{
string u = Request["UserName"];
string p = Request["Password"];
string output = string.Format("'UserName':'{0}','Password':'{1}'",u,p);
Response.Write("[{");
Response.Write(output);
Response.Write("}]");
Response.End();
}
二、JqueryRequest.aspx
通过点击按钮来请求AjaxJson.aspx,获取JSon数据。代码如下:
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" language="javascript" src="js/jquery-1.3.2.js"></script>
</head>
<body>
<form id="form1" runat="server">
<div>
<input type="text" name="Text1" id="Text1"/><br />
<input type="text" name="Text2" id="Text2"/>
<br />
<input type="button" id="btn1" onclick="BtnClick()" />
</div>
<div id="dd">
sd
</div>
<div>
<script type="text/javascript" language="javascript">
function BtnClick() {
var uid = $("#Text1").val();
var pwd = $("#Text2").val();
$.ajax({
url: "AjaxJson.aspx",
type: "POST",
data: { UserName: uid,Password: pwd },
success: function(data) {
var json = eval(data); //eval("(" + data + ")");
$.each(json,function(idx,item) {
var user = item.UserName;
var pass = item.Password;
$("#dd").html("<h1>用户名:" + user + " 密码:" + pass + "</h1>");
});
}
});
}
</script>
</div>
</form>
</body>
</html>