Node.js如何获取服务器数据到页面
沉沙 2018-09-04 来源 : 阅读 816 评论 0

摘要:本篇教程介绍了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频道!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程