想要實(shí)現(xiàn)的的業(yè)務(wù)是先渲染頁面,然后通過ctx.body往頁面中加內(nèi)容核心代碼如下await ctx.render('crawler', { title: '爬取頁面', content: `<h2>開始爬取</h2> <h4>創(chuàng)建地址池成功!</h4>`})const linkPool = createLinkPool()for (let i = 0; i < linkPool.length; ++i) { const html = await requestPage(linkPool[i]) let builds = await dataHandler(html) let arr = []; const sql = 'insert into buildinfo(id,name,area,address,average,price,description,type) values ?' //let rows = await query(sql, [builds]) try { let rows = await query(sql, [builds]) ctx.body += `爬取地址${linkPool[i]}的${rows.affectedRows}條數(shù)據(jù)已經(jīng)入庫` } catch (error) { ctx.body += `${linkPool[i]}的爬取寫入操作失敗了!失敗原因:${error}` }}現(xiàn)在的問題是只有當(dāng)所有寫數(shù)據(jù)庫的操作結(jié)束,頁面才會展示,否則一直在讀小圓圈,請問怎么才能達(dá)到我所預(yù)期的效果我將渲染頁面之后的操作放到一個中間件中了,代碼如下router.get('/crawler/', async (ctx, next) => { await ctx.render('crawler', { title: '爬取頁面', content: `<h2>開始爬取</h2> <h4>創(chuàng)建地址池成功!</h4>` }) next()})頁面渲染之后也確實(shí)執(zhí)行了入庫操作的邏輯,但是ctx.body += `爬取地址${linkPool[i]}的${rows.affectedRows}條數(shù)據(jù)已經(jīng)入庫`這個操作并沒有往頁面上寫內(nèi)容,是不是我的用法不對,請問ctx.body是干什么的?
ctx.render()加載頁面需要等后續(xù)執(zhí)行全部結(jié)束才會顯示最終結(jié)果嗎?
蕪湖不蕪
2019-03-21 22:13:02