亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

node.js+Ajax實現(xiàn)獲取HTTP服務(wù)器返回數(shù)據(jù)

 更新時間:2014年11月26日 12:07:29   投稿:hebedich  
這篇文章主要介紹了node.js+Ajax實現(xiàn)獲取HTTP服務(wù)器返回數(shù)據(jù),講解的十分詳細(xì),也給出了很多的實例,是篇非常不錯的文章,這里推薦給大家。

我們看一個HTML5頁面中通過AJAX請求的方式獲取HTTP服務(wù)器返回數(shù)據(jù)的代碼示例.由于我們把服務(wù)器的端口指定為1337,并將從端口為80的網(wǎng)站中運行HTML5頁面,因此這是一種跨域操作,需要在HTTP響應(yīng)頭部中添加Access_Control_Allow_Origin字段,并且將參數(shù)指定為允許向服務(wù)器請求數(shù)據(jù)額域名+端口號(省略端口號時允許該域名下的任何端口向服務(wù)器請求數(shù)據(jù)),

靜態(tài)頁面:index.html(注:一定要放在服務(wù)器環(huán)境下,如果是win7系統(tǒng)的話,可以開啟IIS服務(wù),并把頁面考過去直接運行這個頁面,)

復(fù)制代碼 代碼如下:

<!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代碼:

復(fù)制代碼 代碼如下:

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)聽...");
});

首先開啟服務(wù):node server.js

啟動靜態(tài)頁面:

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

如果大家覺得需要配置服務(wù)器環(huán)境太麻煩,可以借用編輯器的優(yōu)勢來做.

比如我用的是webstrom 8.0;

當(dāng)我啟動頁面的時候,瀏覽器中顯示的是這個路徑:

端口是63342.這個時候我們隊代碼做一些修改:

node的 server.js代碼:

復(fù)制代碼 代碼如下:

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),達(dá)到同樣的效果

也可以通過res.seetHeader來單獨設(shè)置響應(yīng)頭部.

可以將上面的res.writeHead()改成res.setHeader();

復(fù)制代碼 代碼如下:

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)聽...");
});

細(xì)心的同學(xué)可能發(fā)現(xiàn)了,利用setHeader的方法時,缺少了一個狀態(tài)碼,比如200.那么我們在使用res.setHeader的時候,如何來設(shè)置狀態(tài)碼呢?等會上代碼

ajax在服務(wù)器端返回的時候日期:

我們可以在服務(wù)器端返回時,刪除這個字段.

設(shè)置res.sendData=false;

復(fù)制代碼 代碼如下:

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)聽...");
});

設(shè)置了狀態(tài)碼,也屏蔽了日期信息.

res.getHeader(name)獲取我們設(shè)置的響應(yīng)頭信息

res.removeHeader(name);刪除我們的頭信息.必須在我們的write方法發(fā)送數(shù)據(jù)之情被調(diào)用.

res.headersSent屬性是一個布爾值,當(dāng)當(dāng)響應(yīng)頭已發(fā)送時,屬性值為true時;當(dāng)響應(yīng)頭未發(fā)送時,屬性值為false.

server.js代碼:

復(fù)制代碼 代碼如下:

var http=require("http");
var server=http.createServer(function(req,res){
    if(req.url!=="/favicon.ico"){
        if(res.headersSent)
            console.log("響應(yīng)頭已發(fā)送");
        else
            console.log("響應(yīng)頭未發(fā)送");
        res.writeHead(200,{"Content-Type":"text/plain","Access-Control-Allow-Origin":"http://localhost:63342"});
        if(res.headersSent)
            console.log("響應(yīng)頭已發(fā)送");
        else
            console.log("響應(yīng)頭未發(fā)送");       
        res.write("你好啊!");
    }
    res.end();
});
server.listen(1337,"localhost",function(){
    console.log("開始監(jiān)聽...");
});

運行demo查看結(jié)果:

res.write()方法是向客戶端發(fā)送數(shù)據(jù)的,其實他還有一個返回值.

當(dāng)向客戶端發(fā)送的數(shù)據(jù)量比較小時或網(wǎng)速較快時,node總是將數(shù)據(jù)直接發(fā)送到操作系統(tǒng)的內(nèi)核緩存區(qū)中,然后從內(nèi)核緩存區(qū)中取出數(shù)據(jù)發(fā)送給對方.這個時候write會返回true.

當(dāng)網(wǎng)速慢或數(shù)據(jù)量較大時,http服務(wù)器并不一定會立刻把數(shù)據(jù)發(fā)送給客戶端,node會把數(shù)據(jù)緩存在內(nèi)存中,并在對方可以接受數(shù)據(jù)的情況下將內(nèi)存中的數(shù)據(jù)通過操作系統(tǒng)的內(nèi)核發(fā)送給對方.這時的write返回false.

可以設(shè)置test.txt的內(nèi)容多少來測試結(jié)果.

一個簡單的node+ajax效果就實現(xiàn)了.是不是很簡單呢?當(dāng)然,想制作更加復(fù)雜的功能的話,我們還需要進(jìn)一步的學(xué)習(xí),以后我們慢慢來更新。

相關(guān)文章

  • Node.js使用WebAssembly

    Node.js使用WebAssembly

    本文主要介紹了Node.js使用WebAssembly,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • node將geojson轉(zhuǎn)shp返回給前端的實現(xiàn)方法

    node將geojson轉(zhuǎn)shp返回給前端的實現(xiàn)方法

    這篇文章主要介紹了node將geojson轉(zhuǎn)shp返回給前端的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • npm查看鏡像源與切換鏡像源方法詳解

    npm查看鏡像源與切換鏡像源方法詳解

    這篇文章主要為大家介紹了npm查看鏡像源與切換鏡像源方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 基于node打包可執(zhí)行文件工具_(dá)Pkg使用心得分享

    基于node打包可執(zhí)行文件工具_(dá)Pkg使用心得分享

    下面小編就為大家分享一篇基于node打包可執(zhí)行文件工具_(dá)Pkg使用心得分享,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • node.js遍歷目錄的方法示例

    node.js遍歷目錄的方法示例

    本篇文章主要介紹了node.js遍歷目錄的方法示例,主要介紹了同步遍歷和異步遍歷兩種方法,非常具有實用價值,需要的朋友可以參考下
    2018-08-08
  • 使用命令行升級Node.js的版本的操作指南

    使用命令行升級Node.js的版本的操作指南

    這篇文章主要給大家介紹了關(guān)于如何使用命令行升級Node.js的版本的操作指南,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧
    2023-11-11
  • node.js中的fs.realpathSync方法使用說明

    node.js中的fs.realpathSync方法使用說明

    這篇文章主要介紹了node.js中的fs.realpathSync方法使用說明,本文介紹了fs.realpathSync的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • IDEA中配置運行node.js的完整過程

    IDEA中配置運行node.js的完整過程

    為了使在終端使用npm,我們可以配置環(huán)境變量,這篇文章主要給大家介紹了關(guān)于IDEA中配置運行node.js的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • 手把手教你如何使用nodejs編寫cli命令行

    手把手教你如何使用nodejs編寫cli命令行

    這篇文章主要介紹了手把手教你如何使用nodejs編寫cli命令行,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • nodejs?實現(xiàn)簡單的文件上傳功能(示例詳解)

    nodejs?實現(xiàn)簡單的文件上傳功能(示例詳解)

    這篇文章主要介紹了nodejs?實現(xiàn)簡單的文件上傳功能,文件上傳方式分為三種,本文通過實例代碼給大家詳細(xì)介紹,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02

最新評論