javascript - NodeJS connect模塊use的問題
問題描述
初學(xué)nodejs,在了不起的NodeJS有這樣一段代碼,通過中間件,實(shí)現(xiàn)代碼請求時(shí)間過長的控制臺打印
//request-time.jsmodule.exports = function(opts){ var time = opts.time||100; return function(req,res,next){var timer = setTimeout(function(){ console.log(req.method + ' , ' + req.url + ' , too long!');},time);var end = res.end;res.end = function(chunk,encoding){ res.end = end;// res.end(chunk,encoding);//直接end(chunk,encoding)會出錯(cuò) clearTimeout(timer);};next(); }}
注釋的部分就是本人的疑問,猜測是end里有this的一些東西,不知道理解對不對
問題解答
回答1:閉包” 一詞來源于以下兩者的結(jié)合:要執(zhí)行的代碼塊(由于自由變量被包含在代碼塊中,這些自由變量以及它們引用的對象沒有被釋放)和為自由變量提供綁定的計(jì)算環(huán)境(作用域) ---百度百科
先說下閉包概念
你的理解沒錯(cuò),這個(gè)是驗(yàn)證過程,原因是因?yàn)槿绻阒苯诱{(diào)用end,這個(gè)end是因?yàn)檫@個(gè)閉包強(qiáng)行留下來的,所以會自動(dòng)綁定計(jì)算機(jī)環(huán)境,所以這是后他的this就是Window,所以直接調(diào)用end會出錯(cuò)
相關(guān)文章:
1. html - 移動(dòng)端radio無法選中2. html - IOS二維碼識別問題3. mysql - 這條聯(lián)合sql語句哪里錯(cuò)了4. javascript - vue-resource如何終止之前的ajax請求?5. mysql - 數(shù)據(jù)庫JOIN查詢6. python - 用scrapy-splash爬取網(wǎng)站 為啥iframe下的內(nèi)容沒有被返回7. 我設(shè)置的背景怎么顯示不出來8. mysql - 數(shù)據(jù)庫建字段,默認(rèn)值空和empty string有什么區(qū)別 1109. 關(guān)于Navicat連接到mysql,我改了root的密碼后,Navicat連接報(bào)錯(cuò)1862?10. 正則表達(dá)式 - python pandas的sep參數(shù)問題
