jQuery 中使用JSON的實現(xiàn)代碼
JSON 的格式說明可以在可以這里看到,非常詳細(xì),還是中文的。
JSON 格式說明
需要特別注意的是,在 JSON 中的屬性名是需要使用引號引起來的。
jQuery 中使用 JSON
jQuery 是現(xiàn)在使用廣泛的腳本庫,那么,在 jQuery 中如何使用 JSON 呢?
解析 JSON
在 jQuery 中已經(jīng)提供了對于解析 JSON 的內(nèi)在支持,
jQuery.parseJSON 函數(shù)提供了解析的支持,詳細(xì)的說明見這里。
var obj = jQuery.parseJSON('{"name":"John"}');
alert( obj.name === "John" );
使用對象生成 JSON 格式串
在 jQuery 中并沒有提供直接將普通的 JavaScript 對象轉(zhuǎn)換為 JSON 串的方法,可以使用下面的擴展庫來完成。
jquery-json 擴展庫
這個庫用來擴展 jQuery ,對于 JSON 的使用,擴展了兩個方法。
toJSON 方法用來將一個普通的 JavaScript 對象序列化為 JSON 串。
var thing = {plugin: 'jquery-json', version: 2.3};
var encoded = $.toJSON( thing ); // '{"plugin":"jquery-json","version":2.3}'
evalJSON 方法將一個 JSON 串解析為一個普通的 JavaScript 對象。
var thing = {plugin: 'jquery-json', version: 2.3};
var encoded = $.toJSON( thing ); // '{"plugin":"jquery-json","version":2.3}'
var name = $.evalJSON( encoded ).plugin; // "jquery-json"
var version = $.evalJSON(encoded).version; // 2.3
這個擴展的下載地址:http://code.google.com/p/jquery-json/
使用 jQuery 配合 WCF
客戶端
jQuery 中的 $.post 可以直接向服務(wù)器發(fā)出請求,將服務(wù)器返回的數(shù)據(jù)按照 JSON 方式進行解析,不過,需要注意下面幾點:
請求的內(nèi)容類型必須為 json 格式,這可以通過上面的 jQuery-json 擴展庫來完成,需要特別注意的在請求的 contentType 也必須使用 text/json 進行說明,默認(rèn)的 post 使用普通的名值對方式請求,因此 contentType 是: application/x-www-form-urlencoded,可以通過 $.ajaxSetup 來進行設(shè)置:
// Ajax 設(shè)置
$.ajaxSetup({ contentType: 'text/json' });
這樣,請求的內(nèi)容類型就設(shè)置為需要的類型。
其次,實際的請求內(nèi)容必須使用 JSON 方式,這可以通過擴展庫的 $.toJSON 來實現(xiàn),例如:
$.toJSON({ x: 2, y: 3 })
這樣,如果服務(wù)器端提供了一個服務(wù)方法 Sum,定義如下:
public int Sum(int x, int y)
{
return x + y;
}
就可以如下調(diào)用了。注意,WCF 返回的數(shù)據(jù)在屬性 d 中。
// Ajax 設(shè)置
$.ajaxSetup({ contentType: 'text/json' });
$("#wcfBtn").click(function () {
$.post("Service1.svc/Sum", $.toJSON({ x: 2, y: 3 }), function (data) {
alert(data.d);
});
});
服務(wù)器端的配置
首先,為服務(wù)增加標(biāo)簽:[System.ServiceModel.Activation.AspNetCompatibilityRequirements(
RequirementsMode = System.ServiceModel.Activation.AspNetCompatibilityRequirementsMode.Allowed)]
// #1
// 為了在腳本中使用,必須增加這個標(biāo)簽
[System.ServiceModel.Activation.AspNetCompatibilityRequirements(
RequirementsMode = System.ServiceModel.Activation.AspNetCompatibilityRequirementsMode.Allowed)]
// #2
// 在網(wǎng)站的配置文件中也需要進行設(shè)定
public class Service1 : IService1
{
public int Sum(int x, int y)
{
return x + y;
}
}
然后,在網(wǎng)站的配置文件中,如下配置。
<system.serviceModel>
<!-- 為了支持在瀏覽器端調(diào)用 WCF 服務(wù)的特定配置 -->
<serviceHostingEnvironment aspNetCompatibilityEnabled="true">
<serviceActivations>
<!-- relativeAddress 服務(wù)的地址
service 實現(xiàn)服務(wù)的類型,全名,包含命名空間,甚至程序集
factory 是 WCF 系統(tǒng)提供,直接使用
-->
<add relativeAddress="Service1.svc" service="MServer.Service1" factory="System.ServiceModel.Activation.WebScriptServiceHostFactory"
/>
</serviceActivations>
</serviceHostingEnvironment>
<behaviors>
<serviceBehaviors>
<behavior name="">
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="false" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
jQuery使用JSON的例子
////////////1、在HTML中,有這樣一個表單:
<form method="post" name="searchform" id="searchform" method="/sek.go">
<input name="query" value="" type="text" id="query" />
<input type=”submit” value="查詢"></input>
</form>
////////////當(dāng)然,要想在HTML中使用Js功能,必須在<head/>中加入
<script type="text/javascript"src="/style/js/ajax.js"></script>
////////////2、然后在ajax.js文件中加入如下代碼
function userSearch(){
var query = $("#searchform input[@name='query']").val();
$.post("/userSearch.htm", { query: query } ,function callback(json){
var userlist = $.parseJSON(json);
userList(userlist);
});
}
/*******************************************
解釋如下:
1)、"#searchform input[@name='query']";的意思是: 選擇id為searchform其下的(name屬性值為'query'的)input標(biāo)簽
2)、$(“”).val()意為要得到(“”)所選中屬性的值;
3)、在$.post()中,第一項參數(shù)是指定目標(biāo)servlet,即要把本post請求發(fā)給的那個servlet。
第二項是本post請求所攜帶的數(shù)據(jù);“:”前的為key或者name,后為value;
第三項是回調(diào)函數(shù),其內(nèi)若有形參,則表示要對從servlet返回的值進行處理,這里的callback的功能是將JSON對象json轉(zhuǎn)換成了JS對象userlist,然后將JS對象傳入函數(shù)userList
3、post請求攜帶了名為query的參數(shù)去了后臺,在servlet中進行處理:
//從名為"query"能的參數(shù)中取出post帶過來的數(shù)據(jù)
String query = request.getParameter("query");
if (query != null && !query.isEmpty()
&& !query.trim().equalsIgnoreCase("")) {
//如果"query"的值不為空,就用'query'為參數(shù)構(gòu)建HQL語句
String hql = "from TUser as user where user.userName like '"+ query + "%'";
//到庫表TUser中進行查詢,并得到一個表結(jié)構(gòu)
List list = weilav3TUserDAO.getListByHQL(hql);
if (list != null && !list.isEmpty()) {
//若list不為空,則將其轉(zhuǎn)換成JSON對象,并存入jsonArray中
JSONArray jsonArray = JSONArray.fromObject(list);
//下面就是把存有查詢結(jié)果的JSON對象返給頁面
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
out.println(jsonArray);
……
}else {……}
**************/
相關(guān)文章
JQuery擴展插件Validate—4設(shè)置錯誤提示的樣式
JQuery擴展插件Validate—4設(shè)置錯誤提示的樣式,使用Validate的朋友可以參考下。2011-09-09Jquery根據(jù)瀏覽器窗口改變調(diào)整大小的方法
下面小編就為大家?guī)硪黄狫query根據(jù)瀏覽器窗口改變調(diào)整大小的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02實例代碼講解jquery easyui動態(tài)tab頁
這篇文章主要介紹了實例代碼講解jquery easyui動態(tài)tab頁的相關(guān)資料,需要的朋友可以參考下2015-11-11