首頁 > web前端 > js教程 > 淺析node Express框架中的 res.send() 和 res.end()

淺析node Express框架中的 res.send() 和 res.end()

青灯夜游
發布: 2022-01-27 18:17:28
轉載
2216 人瀏覽過

這篇文章帶大家聊聊node Express框架,了解Express 中的 res.send() 和 res.end(),希望對大家有幫助!

淺析node Express框架中的 res.send() 和 res.end()

在使用Node.js# 的服務端程式碼中,如果使用的是Express 框架,那麼對於一個請求,常常會有兩種回應方式:

// 方法1
app.get("/end", (req, res, next) =>{
    res.end(xxx);
});
// 方法2
app.get("/send", (req, res, next) =>{
    res.send(xxx);
});
登入後複製

那麼這兩種方式究竟有何不同?各自的應用場景分別是什麼?這是我今天需要講清楚的。

Express 之res.end()

定義

#它可以在不需要任何資料的情況下快速結束響應。

這個方法其實是來自Node 核心,具體來說是http.ServerResponse.Useresponse.end() 方法:

淺析node Express框架中的 res.send() 和 res.end()

#語法

res.end([data[, encoding]][, callback])
登入後複製

參數解析:

  • data |
  • encoding
  • callback

淺析node Express框架中的 res.send() 和 res.end()

##如果給

res.end()

方法傳入一個對象,會發生報錯:

Express 之res.send()

定義

向請求客戶端發送HTTP 回應訊息。

語法

res.send([body[,statusCode]])
登入後複製

body 參數可以是 Buffer、Object、String、Boolean 或 Array。

深入

透過程式碼調試,我們可以發現,Express 的

res.send()

方法最終調用的也是
    http.ServerResponse.Use
  • response.end() 方法:

    // node_modules/express/lib/response.js
    res.send = function send(body) {
      var chunk = body;
      var encoding;
      ……
      if (req.method === 'HEAD') {
        // skip body for HEAD
        this.end();
      } else {
        // respond
        this.end(chunk, encoding);
      }
      return this;
    };
    登入後複製
    對比
  • 相同點

  • Express 的res.end() 和res.send() 方法的相同點:

    二者最後都是回歸到  http.ServerResponse.Use

    response.end()

    方法。
    • 二者都會結束目前回應流程。
    不同點

    #Express 的res.end() 和res.send() 方法的不同點:

    前者只能傳送string 或Buffer 類型,後者可以傳送任何類型資料。

    從語意來看,前者更適合沒有任何回應資料的場景,而後者更適合存在回應資料的場景。 ############總結######Express 的res.end() 和res.send() 方法使用上,一般建議使用###res.send()###方法即可,這樣就不需要關心回應資料的格式,因為Express 內部已經處理了資料。 ######~本文完,感謝閱讀! ######更多node相關知識,請造訪:###nodejs 教學###! ! ###

    以上是淺析node Express框架中的 res.send() 和 res.end()的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:juejin.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板