摘要:本篇教程介绍了Node.js如何获取服务器数据到页面,希望阅读本篇文章以后大家有所收获,帮助大家对Node.js的理解更加深入。
本篇教程介绍了Node.js如何获取服务器数据到页面,希望阅读本篇文章以后大家有所收获,帮助大家对Node.js的理解更加深入。
<
const Koa = require(‘koa‘);
const Router = require(‘koa-router‘);
const app = new Koa();
const router = new Router();
const views = require(‘koa-views‘);
const json = require(‘koa-json‘);
const onerror = require(‘koa-onerror‘);
const bodyparser = require(‘koa-bodyparser‘);
const path = require(‘path‘);
const logger = require(‘koa-logger‘);
const request = require(‘request‘);
// error handler
onerror(app)
// middlewares
app.use(bodyparser())
.use(json())
.use(logger())
.use(require(‘koa-static‘)(__dirname + ‘/public‘))
.use(views(path.join(__dirname, ‘/views‘), {
options: { settings: { views: path.join(__dirname, ‘views‘) } },
map: { ‘html‘: ‘nunjucks‘ },
extension: ‘html‘
}))
.use(router.routes())
.use(router.allowedMethods())
// x-response-time
app.use(async function(ctx, next) {
const start = new Date();
await next();
const ms = new Date() - start;
ctx.set(‘X-Response-Time‘, `${ms}ms`);
});
// logger
app.use(async function(ctx, next) {
const start = new Date();
await next();
const ms = new Date() - start;
console.log(`${ctx.method} ${ctx.url} - ${ms}`);
});
app.on(‘error‘, (err, ctx) =>
log.error(‘server error‘, err, ctx)
);
router.get(‘/‘, async(ctx, next) => {
var bd = "bd";
// 从服务器获取数据
bd = await getData();
ctx.state = {
title: ‘Koa2‘,
name: bd
}
// 发送到页面
return await ctx.render(‘index‘, ctx.state)
})
//获取服务器数据
async function getData(){
return new Promise((resolve,reject)=>{
request("https://www.baidu.com",(error,response,body)=>{
if(error){
reject("error")
}else{
resolve("thank you");//body
}
})
})
}
router.get(‘/b‘, async(ctx, next) => {
ctx.state = {
title: ‘Koa2‘,
name: ‘小明-list‘
}
await ctx.render(‘b‘, ctx.state)
})
app.listen(3000);
console.log(‘listen //localhost:3000‘);
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注WEB前端Node.js频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号