這篇文章主要介紹了node.js+Ajax實現(xiàn)獲取HTTP服務器返回數(shù)據(jù),講解的十分詳細,也給出了很多的實例,是篇非常不錯的文章,這里推薦給大家。
我們看一個HTML5頁面中通過AJAX請求的方式獲取HTTP服務器返回數(shù)據(jù)的代碼示例.由于我們把服務器的端口指定為1337,并將從端口為80的網(wǎng)站中運行HTML5頁面,因此這是一種跨域操作,需要在HTTP響應頭部中添加Access_Control_Allow_Origin字段,并且將參數(shù)指定為允許向服務器請求數(shù)據(jù)額域名+端口號(省略端口號時允許該域名下的任何端口向服務器請求數(shù)據(jù)),
靜態(tài)頁面:index.html(注:一定要放在服務器環(huán)境下,如果是win7系統(tǒng)的話,可以開啟IIS服務,并把頁面考過去直接運行這個頁面,)
復制代碼代碼如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>node中的ajax請求(html5頁面)</title>
<script type="text/javascript">
function GetData(){
var xhr=new XMLHttpRequest();
xhr.open("GET","http://localhost:1337/",true);
xhr.onreadystatechange=function(){
if(xhr.readyState==4){
if(xhr.status==200){
document.getElementById("res").innerHTML=xhr.responseText;
}
}
}
xhr.send(null);
}
</script>
</head>
<body>
<input type="button" value="獲取數(shù)據(jù)" onclick="GetData()" />
<div id="res">dsdf</div>
</body>
</html>
node代碼:
復制代碼代碼如下:
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost"});
res.write("你好啊!");
}
res.end();
});
server.listen(1337,"localhost",function(){
console.log("開始監(jiān)聽...");
});
首先開啟服務:node server.js
啟動靜態(tài)頁面:

點擊按鈕"獲取數(shù)據(jù)"

如果大家覺得需要配置服務器環(huán)境太麻煩,可以借用編輯器的優(yōu)勢來做.
比如我用的是webstrom 8.0;
當我啟動頁面的時候,瀏覽器中顯示的是這個路徑:

端口是63342.這個時候我們隊代碼做一些修改:
node的 server.js代碼:
復制代碼代碼如下:
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
//res.setHeader();
res.write("你好啊!");
}
res.end();
});
server.listen(1337,"localhost",function(){
console.log("開始監(jiān)聽...");
});
修改了"Access-Control-Allow-Origin"的值.
重新運行demo會發(fā)現(xiàn),達到同樣的效果
也可以通過res.seetHeader來單獨設置響應頭部.
可以將上面的res.writeHead()改成res.setHeader();
復制代碼代碼如下:
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
//res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
res.setHeader("Content-Type","text/plain");
res.setHeader("Access-Control-Allow-Origin","http://localhost:63342");
res.write("你好啊!");
}
res.end();
});
server.listen(1337,"localhost",function(){
console.log("開始監(jiān)聽...");
});
細心的同學可能發(fā)現(xiàn)了,利用setHeader的方法時,缺少了一個狀態(tài)碼,比如200.那么我們在使用res.setHeader的時候,如何來設置狀態(tài)碼呢?等會上代碼
ajax在服務器端返回的時候日期:

我們可以在服務器端返回時,刪除這個字段.
設置res.sendData=false;
復制代碼代碼如下:
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
//res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
res.statusCode=200;
res.sendDate=false;
res.setHeader("Content-Type","text/plain");
res.setHeader("Access-Control-Allow-Origin","http://localhost:63342");
res.write("你好啊!");
}
res.end();
});
server.listen(1337,"localhost",function(){
console.log("開始監(jiān)聽...");
});

設置了狀態(tài)碼,也屏蔽了日期信息.
res.getHeader(name)獲取我們設置的響應頭信息
res.removeHeader(name);刪除我們的頭信息.必須在我們的write方法發(fā)送數(shù)據(jù)之情被調(diào)用.
res.headersSent屬性是一個布爾值,當當響應頭已發(fā)送時,屬性值為true時;當響應頭未發(fā)送時,屬性值為false.
server.js代碼:
復制代碼代碼如下:
var http=require("http");
var server=http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
if(res.headersSent)
console.log("響應頭已發(fā)送");
else
console.log("響應頭未發(fā)送");
res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
if(res.headersSent)
console.log("響應頭已發(fā)送");
else
console.log("響應頭未發(fā)送");
res.write("你好啊!");
}
res.end();
});
server.listen(1337,"localhost",function(){
console.log("開始監(jiān)聽...");
});
運行demo查看結果:

res.write()方法是向客戶端發(fā)送數(shù)據(jù)的,其實他還有一個返回值.
當向客戶端發(fā)送的數(shù)據(jù)量比較小時或網(wǎng)速較快時,node總是將數(shù)據(jù)直接發(fā)送到操作系統(tǒng)的內(nèi)核緩存區(qū)中,然后從內(nèi)核緩存區(qū)中取出數(shù)據(jù)發(fā)送給對方.這個時候write會返回true.
當網(wǎng)速慢或數(shù)據(jù)量較大時,http服務器并不一定會立刻把數(shù)據(jù)發(fā)送給客戶端,node會把數(shù)據(jù)緩存在內(nèi)存中,并在對方可以接受數(shù)據(jù)的情況下將內(nèi)存中的數(shù)據(jù)通過操作系統(tǒng)的內(nèi)核發(fā)送給對方.這時的write返回false.

可以設置test.txt的內(nèi)容多少來測試結果.
一個簡單的node+ajax效果就實現(xiàn)了.是不是很簡單呢?當然,想制作更加復雜的功能的話,我們還需要進一步的學習,以后我們慢慢來更新。