javascript - nodejs 優(yōu)化問題
問題描述
如果我需要用nodejs 請求多個java的接口最后得到所有數(shù)據(jù)渲染頁面,怎么樣能提高速度之前我是這樣的
//請求接口 http.tp(options,function(error,response,tags){http.tp(options1,function(error,response,topic){ http.tp(follow,function(error,response,follow){http.tp(options2,function(error,response,topicRCMD){ data={follow:follow,topicRCMD:topicRCMD,tags:tags,topicHot:topic, } opt.render(data); //渲染頁面}) })}) })
這樣速度很慢。然后我引用async
return async.parallel({//我關(guān)注的人follow:function(callback){ http.tp(follow,function(error, response, follow){callback(null, follow); })},// 獲取標(biāo)簽tags:function(callback){ http.tp(options,function(error, response, tags){callback(null, tags); })},// 獲取熱門話題topicHot:function(callback){ http.tp(options1,function(error, response, topicHot){callback(null, topicHot); })},// 獲取推薦話題列表topicRCMD:function(callback){ http.tp(options2,function(error, response, topicRCMD){callback(null, topicRCMD); })} }, function(err, results){console.log(’ssss:’,results);opt.render(results); //渲染頁面 });
這樣子速度變快了點(diǎn),但還是很慢,請問這個有什么好的解決辦法嗎
問題解答
回答1:第一個方法慢是因?yàn)樾枰ㄙM(fèi)的時間是所有請求時間的總和;第二種方法只需要花費(fèi)最長的那個請求需要的時間,自然會快一些再想優(yōu)化了就需要在渲染過程或者服務(wù)器端請求處理過程上優(yōu)化了
回答2:只能用promise.all類似的了吧,如果有什么好的方法可以告訴我。
回答3:這個問題其實(shí)是渲染的策略問題,其實(shí)不需要在Node把所有數(shù)據(jù)請求完全后再發(fā)送到客戶端。
完全可以把這個請求數(shù)據(jù)的步驟放到客戶端,然后客戶端ajax獲取數(shù)據(jù)。這就不需要等所有數(shù)據(jù)獲取完。
回答4:可以用es6語法中新增的promise,專門解決你這種回調(diào)黑洞的情況。
回答5:感覺需要考慮兩點(diǎn),第一,你所有的都是依賴前一個嗎?有沒有可能并行發(fā)一些請求;第二,有沒有可能分清主次,讓客戶端去發(fā)請求,畢竟客戶端視窗就那么大,主次關(guān)系會很明確,客戶端發(fā)請求,先發(fā)重要的,用戶首屏加載會看到的,再發(fā)后面的;
相關(guān)文章:
1. css - 移動端 oppo 手機(jī)之 Border-radius2. javascript - vue提示語法錯誤,請問錯誤在哪?3. 淺談vue生命周期共有幾個階段?分別是什么?4. index.php錯誤,求指點(diǎn)5. python - 抓包只抓到j(luò)son,真實(shí)的地址卻找不到6. css - 關(guān)于偽類背景問題7. html - JavaScript的Dom操作如何改變子元素的文本內(nèi)容8. java - web端百度網(wǎng)盤的一個操作為什么要分兩次請求服務(wù)器, 有什么好處嗎9. javascript - 為什么我的animation-fill-mode 設(shè)置不生效10. javascript - vue.js如何遞歸渲染組件.
