Jquery經過ajax請求NodeJS返回json數據

最近看了NodeJS相關的,在網上查了下結合AJAX的應用,感受應用前景仍是不錯的。爲何用這個組合呢?html

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

         2.經過HTML的ajax請求,能夠實如今不一樣的服務器上,可跨域獲取數據。jquery

          3.通訊數據格式靈活,能夠是xml、json、binary等,數據適合任何平臺。ajax

在說說個人環境,我使用的是公司提供的電腦,有不少限制,好比是域中電腦,操做權限低,沒法安裝任何軟件,沒法修改計算機配置,沒法使用U盤等等。因此我就本身配置了一個nodejs的綠色版環境,只能在當前cmd窗口運行nodejs的相關環境;沒法架設html服務器,因此就單獨在D盤建立一個html文件雙擊打開使用。json

1、node環境就不說了,能夠查看個人博客的配置跨域

2、編寫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"}app

經過node app.js的方式運行起來,而後就可讓html經過ajax訪問數據了。函數

另外就是我建立的html文件,文件aaa.html內容以下:post

<!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

 

 

以上環境都是本人親自測試,若有轉載請註明出處。

相關文章
相關標籤/搜索