日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

Jquery通过ajax请求NodeJS返回json数据

發(fā)布時(shí)間:2025/5/22 javascript 138 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Jquery通过ajax请求NodeJS返回json数据 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

最近看了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)。

在說(shuō)說(shuō)我的環(huán)境,我使用的是公司提供的電腦,有很多限制,比如是域中電腦,操作權(quán)限低,無(wú)法安裝任何軟件,無(wú)法修改計(jì)算機(jī)配置,無(wú)法使用U盤等等。所以我就自己配置了一個(gè)nodejs的綠色版環(huán)境,只能在當(dāng)前cmd窗口運(yùn)行nodejs的相關(guān)環(huán)境;無(wú)法架設(shè)html服務(wù)器,所以就單獨(dú)在D盤創(chuàng)建一個(gè)html文件雙擊打開使用。

一、node環(huán)境就不說(shuō)了,可以查看我的博客的配置

二、編寫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)行起來(lái),然后就可以讓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)的注釋說(shuō)明,這里就不再解釋了,其中用到的jquery的js文件自己去網(wǎng)上下載一個(gè),也同樣放到當(dāng)前html文件的目錄下。
有一點(diǎn)說(shuō)明下:我下載了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è)試,如有轉(zhuǎn)載請(qǐng)注明出處。

總結(jié)

以上是生活随笔為你收集整理的Jquery通过ajax请求NodeJS返回json数据的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。