Jquery通過ajax請(qǐng)求NodeJS返回json數(shù)據(jù)實(shí)例
最近看了NodeJS相關(guān)的,在網(wǎng)上查了下結(jié)合AJAX的應(yīng)用,感覺應(yīng)用前景還是不錯(cuò)的。為什么用這個(gè)組合呢?
1.NodeJS不需要安裝,拷貝過去就可以使用,而環(huán)境變量可以只配置在當(dāng)前cmd窗口,運(yùn)行方便。
2.通過HTML的ajax請(qǐng)求,可以實(shí)現(xiàn)在不同的服務(wù)器上,可跨域獲取數(shù)據(jù)。
3.通信數(shù)據(jù)格式靈活,可以是xml、json、binary等,數(shù)據(jù)適合任何平臺(tái)。
在說說我的環(huán)境,我使用的是公司提供的電腦,有很多限制,比如是域中電腦,操作權(quán)限低,無法安裝任何軟件,無法修改計(jì)算機(jī)配置,無法使用U盤等等。所以我就自己配置了一個(gè)nodejs的綠色版環(huán)境,只能在當(dāng)前cmd窗口運(yùn)行nodejs的相關(guān)環(huán)境;無法架設(shè)html服務(wù)器,所以就單獨(dú)在D盤創(chuàng)建一個(gè)html文件雙擊打開使用。
一、node環(huán)境就不說了,可以查看以下幾篇文章
http://chabaoo.cn/article/33086.htm
http://chabaoo.cn/article/54678.htm
http://chabaoo.cn/article/57687.htm
二、編寫node執(zhí)行的腳本,腳本文件app.js如下:
var http = require("http");
var fs = require("fs");
var str='{"id":"123",name:"jack",arg:11111}';
function onRequest(request, response){
console.log("Request received.");
response.writeHead(200,{"Content-Type":'text/plain','charset':'utf-8','Access-Control-Allow-Origin':'*','Access-Control-Allow-Methods':'PUT,POST,GET,DELETE,OPTIONS'});//可以解決跨域的請(qǐng)求
//response.writeHead(200,{"Content-Type":'application/json', 'Access-Control-Allow-Origin':'*','Access-Control-Allow-Methods':'PUT,POST,GET,DELETE,OPTIONS'});
//response.write("Hello World 8888\n");
str=fs.readFileSync('data.txt');
response.write(str);
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.port on 8888\n");
console.log("test data: "+str.toString());
其中data.txt和當(dāng)前app.js文件的放到相同的目錄下,data.txt中代碼是json格式的數(shù)據(jù):{"id":"123",name:"jack",arg:321,remark:"test data"}
通過node app.js的方式運(yùn)行起來,然后就可以讓html通過ajax訪問數(shù)據(jù)了。
另外就是我創(chuàng)建的html文件,文件aaa.html內(nèi)容如下:
<!DOCTYPE html>
<html>
<head>
<title>Node JS 實(shí)例</title>
<script src="jquery-1.4.4.min.js"></script>
<script>
/*
//可用于檢查出錯(cuò)函數(shù)的錯(cuò)誤內(nèi)容,一般使用$.get()和$.post()函數(shù)就可以了
$.ajax({
url: "http://127.0.0.1:8888/",
type: "GET",
dataType: "binary", //因?yàn)槭钦{(diào)用nodeJS返回的json數(shù)據(jù),所以必須使用binary類型
error: function(XMLHttpRequest, textStatus, errorThrown){
var s1=XMLHttpRequest;
var s2=textStatus;
var s3=errorThrown;
alert("error message : "+errorThrown.toString())
},
success: function(data){
$("#feeds").html(data);
var dataObj=eval('('+data+')');//轉(zhuǎn)換為json對(duì)象
$("#id").html("編號(hào):"+dataObj.id);
$("#name").html("姓名:"+dataObj.name);
$("#arg").html("年齡:"+dataObj.arg);
$("span").html(dataObj.remark);
// alert( "Data is : " + data );
}
});
*/
//$.get("test.cgi", function(data){ alert("Data Loaded: " + data); }); //$.get函數(shù)形式結(jié)構(gòu)
$.get("http://127.0.0.1:8888/" + new Date().getTime(), function(data){
$("#feeds").html(data);
var dataObj=eval('('+data+')');//轉(zhuǎn)換為json對(duì)象
$("#id").html("編號(hào):"+dataObj.id);
$("#name").html("姓名:"+dataObj.name);
$("#arg").html("年齡:"+dataObj.arg);
$("span").html(dataObj.remark);
//alert("Data Loaded: "+new Date().getTime());
});
</script>
</head>
<body>
<div id="feeds"></div>
<div id=id></div>
<div id=name></div>
<div id=arg></div>
<span>ddddd</span>
</body>
</html>
文件中都做了相應(yīng)的注釋說明,這里就不再解釋了,其中用到的jquery的js文件自己去網(wǎng)上下載一個(gè),也同樣放到當(dāng)前html文件的目錄下。
有一點(diǎn)說明下:我下載了jquery的1.8.3版和2.1.4版都會(huì)報(bào)錯(cuò),可能對(duì)json的支持不是很好,使用1.4.4版可正常運(yùn)行,其他版本沒有測(cè)試。
在我本機(jī)和內(nèi)網(wǎng)測(cè)試正常顯示如下:
{"id":"123",name:"jack",arg:32100, remark:"test data"}
編號(hào):123
姓名:jack
年齡:32100
test data
以上環(huán)境都是本人親自測(cè)試,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery側(cè)邊欄隨窗口滾動(dòng)實(shí)現(xiàn)方法
jQuery側(cè)邊欄隨窗口滾動(dòng)實(shí)現(xiàn)方法,需要的朋友可以參考一下2013-03-03
web前端設(shè)計(jì)師們常用的jQuery特效插件匯總
這篇文章主要匯總了web前端設(shè)計(jì)師們常用的jQuery特效插件,需要的朋友可以參考下2014-12-12
jQuery實(shí)現(xiàn)調(diào)整表格單列順序完整實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)調(diào)整表格單列順序的方法,結(jié)合完整實(shí)例形式分析了jQuery響應(yīng)鼠標(biāo)事件及動(dòng)態(tài)操作頁面元素的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
jQuery-ui中自動(dòng)完成實(shí)現(xiàn)方法
關(guān)于jQuery-ui-1.8中的自動(dòng)完成控件,其匹配方式是使用正則表達(dá)式進(jìn)行匹配的。2010-06-06
仿新浪微博返回頂部的jquery實(shí)現(xiàn)代碼
在web頁面中,如果頁面較高,為了方便用戶快速地返回頂部,都會(huì)添加一個(gè)返回頂部按鈕2012-10-10

