最近看了NodeJS相關的,在網路上查了一下結合AJAX的應用,感覺應用前景還是不錯的。為什麼要用這個組合呢?
1.NodeJS不需要安裝,拷貝過去就可以使用,而環境變數可以只配置在目前cmd窗口,運作方便。
2.透過HTML的ajax請求,可以實現在不同的伺服器上,可跨網域取得資料。
3.通訊資料格式靈活,可以是xml、json、binary等,資料適合任何平台。
在說說我的環境,我使用的是公司提供的電腦,有很多限制,比如是域中電腦,操作權限低,無法安裝任何軟體,無法修改電腦配置,無法使用U盤等等。所以我就自己配置了一個nodejs的綠色版環境,只能在目前cmd視窗運行nodejs的相關環境;無法架設html伺服器,所以就單獨在D盤創建一個html檔雙擊開啟使用。
編寫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
以上環境都是自己親自測試,希望對大家的學習有所幫助,多多支持PHP中文網