koa 基礎(十)原生node.js 在 koa 中獲取表單提交的數據

1.app.jsjavascript

// 引入模塊
const Koa = require('koa');
const router = require('koa-router')(); /*引入是實例化路由 推薦*/
const views = require('koa-views');
const common = require('./module/common.js');

// 實例化
let app = new Koa();

// 應用ejs模板引擎
app.use(views('views', { map: { html: 'ejs' } }));

router.get('/', async (ctx) => {
  await ctx.render('index');
})

// 接收post提交的數據
router.post('/doAdd', async (ctx) => {
  // 原生node.js 在 koa 中獲取表單提交的數據
  let data = await common.getPostData(ctx);
  console.log(data);

  ctx.body = data;
})

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

app.listen(3000);

2.module/common.jshtml

exports.getPostData = function (ctx) {
  // 獲取數據 異步
  return new Promise(function (resolve, reject) {
    try {
      let str = '';
      ctx.req.on('data', function (chunk) {
        str += chunk;
      })

      ctx.req.on('end', function (chunk) {
        resolve(str)
      })
    } catch (err) {
      reject(err);
    }
  })
}

3.index.htmljava

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <form action="/doAdd" method="post">
    用戶名:<input type="text" name="username" />
    <br /> 密碼: <input type="password" name="password" />
    <br />
    <button type="submit">提交</button>
  </form>
</body>

</html>

4.目錄node

5.效果圖app

相關文章
相關標籤/搜索