国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Jquery通過ajax請求NodeJS返回json數據實例

2019-11-19 19:01:31
字體:
來源:轉載
供稿:網友

最近看了NodeJS相關的,在網上查了下結合AJAX的應用,感覺應用前景還是不錯的。為什么用這個組合呢?

1.NodeJS不需要安裝,拷貝過去就可以使用,而環境變量可以只配置在當前cmd窗口,運行方便。

2.通過HTML的ajax請求,可以實現在不同的服務器上,可跨域獲取數據。

3.通信數據格式靈活,可以是xml、json、binary等,數據適合任何平臺。

在說說我的環境,我使用的是公司提供的電腦,有很多限制,比如是域中電腦,操作權限低,無法安裝任何軟件,無法修改計算機配置,無法使用U盤等等。所以我就自己配置了一個nodejs的綠色版環境,只能在當前cmd窗口運行nodejs的相關環境;無法架設html服務器,所以就單獨在D盤創建一個html文件雙擊打開使用。

一、node環境就不說了,可以查看以下幾篇文章

//www.survivalescaperooms.com/article/33086.htm

//www.survivalescaperooms.com/article/54678.htm

//www.survivalescaperooms.com/article/57687.htm

二、編寫node執行的腳本,腳本文件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'});//可以解決跨域的請求 //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和當前app.js文件的放到相同的目錄下,data.txt中代碼是json格式的數據:{"id":"123",name:"jack",arg:321,remark:"test data"}

通過node app.js的方式運行起來,然后就可以讓html通過ajax訪問數據了。

另外就是我創建的html文件,文件aaa.html內容如下:

<!DOCTYPE html><html><head> <title>Node JS 實例</title><script src="jquery-1.4.4.min.js"></script><script>/*//可用于檢查出錯函數的錯誤內容,一般使用$.get()和$.post()函數就可以了$.ajax({ url: "http://127.0.0.1:8888/", type: "GET", dataType: "binary", //因為是調用nodeJS返回的json數據,所以必須使用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+')');//轉換為json對象 $("#id").html("編號:"+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函數形式結構$.get("http://127.0.0.1:8888/" + new Date().getTime(), function(data){ $("#feeds").html(data);var dataObj=eval('('+data+')');//轉換為json對象$("#id").html("編號:"+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>

文件中都做了相應的注釋說明,這里就不再解釋了,其中用到的jquery的js文件自己去網上下載一個,也同樣放到當前html文件的目錄下。

有一點說明下:我下載了jquery的1.8.3版和2.1.4版都會報錯,可能對json的支持不是很好,使用1.4.4版可正常運行,其他版本沒有測試。

在我本機和內網測試正常顯示如下:

{"id":"123",name:"jack",arg:32100, remark:"test data"}
編號:123
姓名:jack
年齡:32100
test data

以上環境都是本人親自測試,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南京市| 华亭县| 阿荣旗| 鄢陵县| 正阳县| 达孜县| 呼伦贝尔市| 临猗县| 丹阳市| 阳信县| 治县。| 芦溪县| 上犹县| 龙江县| 弥渡县| 定远县| 定日县| 通州区| 静海县| 柘荣县| 遂宁市| 河东区| 常州市| 南康市| 左贡县| 石嘴山市| 赤峰市| 扎赉特旗| 甘南县| 枞阳县| 门源| 兰坪| 德江县| 泰和县| 水富县| 明溪县| 万年县| 潜江市| 自治县| 久治县| 华池县|