91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node.js獲取前端ajax提交的request信息

發布時間:2020-09-10 17:39:01 來源:腳本之家 閱讀:186 作者:HaoDaWang 欄目:web開發

今天看一下Node.js怎么獲取ajax提交的request 信息

眾所周知,ajax可以在不刷新整個頁面的情況下實現局部刷新,這是相當好的一種方式,能夠讓我們動態更新信息,今天我們看一下怎么用node來接收到前端ajax提交過來的信息

下面我貼一下前端的代碼
index.html的代碼我就不貼了, 因為里面就只有一個按鈕而已,要實現的功能是點擊按鈕提交ajax異步請求

主要貼一下js頁面的代碼

$("button").on("click",function(){
  //提交ajax請求
  $.ajax({
    url:"http://localhost:9999",
    data:{name:'xiaoming',age:19},
    type:"POST",
    dataType:"json",
    async:true,
    timeout:5000,
    complete:function(){
      console.log("end");
    },
    success:function(data,textStatus,jqXHR){
      console.log(data);
      console.log(textStatus);
      console.log(jqXHR);
    },
    error:function(textStatus,jqXHR){
      console.log("error");
      console.log(textStatus);
      console.log(jqXHR);
    }
  });
});

這樣我們就已經異步提交了一個ajax請求給服務端。

由于我的服務端是用node寫的,我貼一下node.js的代碼

/**
 * New node file
 */

//載入模塊
var http = require("http");
function onRequest(req,resp){
  //獲取ajax提交的信息
  req.on("data",function(data){
    //打印
    console.log(decodeURIComponent(data));
  });
  //返回response
  resp.writeHead(200,{"ContentType":"text/html;charset=utf-8"});
  //返回響應尾
  resp.end();
}

//創建服務器
http.createServer(onRequest).listen(9999);

服務器獲取的結果如下:

name=xiaoming&age=19

乍一看,其實獲取ajax的請求信息是非常簡單,我在node里創建了服務器,然后給request添加data事件,做了一個回調處理,然后就可以獲取到ajax提交過來的數據了

但是這樣的話,我們還是不能靈活的使用這個數據,我們必須用split將其name和age的value分割出來,這是相當不方便的。

于是我們想到了用querystring來解析為json對象,我們只需要稍稍修改一下剛剛的代碼就可以實現

/**
 * New node file
 */

//載入模塊
var http = require("http");
var qs = require("querystring");
function onRequest(req,resp){
  //獲取ajax提交的信息
  var currentData = "";
  req.on("data",function(data){
    //打印
    currentData += data;
    console.log(qs.parse(currentData));
  });
  //返回response
  resp.writeHead(200,{"ContentType":"text/html;charset=utf-8"});
  //返回響應尾
  resp.end();
}

//創建服務器
http.createServer(onRequest).listen(9999);

下面是運行的結果

{ name: 'xiaoming', age: '19' }

我們也可以將它裝到一個變量里,然后使用它的各種屬性

var temp = qs.parse(data);
console.log(temp.name);
console.log(temp.age);

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江口县| 衡阳市| 于田县| 望奎县| 秀山| 宜宾市| 全州县| 太仓市| 上犹县| 郎溪县| 屏边| 云浮市| 永康市| 贵定县| 鄱阳县| 广西| 济阳县| 莎车县| 阿鲁科尔沁旗| 和政县| 东平县| 南华县| 华安县| 恩施市| 濮阳市| 江门市| 焦作市| 咸丰县| 庐江县| 岱山县| 汾阳市| 彩票| 泽库县| 新和县| 冕宁县| 韶山市| 平邑县| 和顺县| 洛南县| 姚安县| 芮城县|