async await 异步的简单用法

async  是声明一个异步函数,如  async ()=>{}

await 是等待一个异步方法执行,await 执行函数必须出现在 async 内部。如

async  function test(){

     let result =  await  new Promise.resolve('123456');

      console.log(result); //123456

}

test();

简单的应用:

const test  = function(params){   //参数

        return new Promise((resolve, reject) => {

                    ....执行方法

                     resolve(result)  //结果通过resolve的方式返回

                    reject(err)    //错误通过reject的方式抛出

        });

}

async  demo () => {

     let  result = await  test(params);  //result接收返回的处理结果

}

demo()    //执行函数

async  await  链接数据库:(cnpm install mysql --S)

var mysql = require('mysql');

var pool = mysql.createPool({

        host:'127.0.0.1',

        user:'root',

        password:'',

        port:'3306',

        database:''

});

var query = function(sql, values){

        return new Promise((resolve, reject) => {

                pool.getConection(function(err, connection){

                        connection.query(sql, function(err,  rows){

                                if(err){

                                        reject(err);

                                }

                                resolve(rows);

                        })

                });

        });

}

async  function demo(){

        let sql = "select 1+1";

        let result = await query(sql);

        console.log(result);   // 2

}

demo();

//exports.default = query;


async   await  在koa2.x 路由中的简单应用:(cnpm install koa-router --S/yarn add koa-router)

const  Router = require('koa-router');

const routers = new Router();

const query = require('./mysql.js');

routers.get('/', async (ctx, next) => {

              var sql = "select 1+1";  

              let result = await query(sql);

            console.log(result);

})

app.use(routers.routes()).use(routes.allowedMethods());

app.listen(3000, ()=>{

        console.log('server port 3000 is runing');

});

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容