Как получить значение textarea при отправке формы в nodejs - PullRequest
0 голосов
/ 21 июня 2019

Я получаю неопределенный ответ на req.body.numbers. Как мы можем получить значение textarea в nodejs.

<form method="POST" action="/messaging">
    <h4>Mobile Numbers</h4>
    <textarea id="numbers" class="number-area" name="numbers"></textarea>
    <h4>Add a Message</h4>
    <textarea id="message" class="message-area" name="message"></textarea>
    <br>
    <div>
        <button class="btn btn-outline-success" type="submit">
            Send
        </button>
    </div>
</form>
exports.postMessaging = (req, res, next) => {
  const numbers = req.body.numbers;
  console.log(numbers);

Ответы [ 2 ]

0 голосов
/ 21 июня 2019

Эта запись поможет вам понять, как отправлять данные из HTML в код node.js.

Отредактированный

App.js

const express = require('express');
const bodyParser = require('body-parser');
const app = exports.module = express();
app.use(bodyParser.urlencoded({ extended: true })); 

app.post('/test', function(req, res) {
  var lName = req.body.lname;
  var number = req.body.numbers;
  res.send();
})

app.listen(1337, function() {
  console.log('App is running on 1337');
})

index.html

<!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="http://localhost:1337/test" method="POST">
        <input name="lname" id="lname"/>
        <textarea id="numbers" class="number-area" name="numbers"></textarea>
        <button type="submit">Submit</button>
    </form>
</body>
</html>

package.json - для справки

"body-parser": "^1.19.0",
"express": "^4.17.1"

Приведенный выше код работает и принимает идентификаторы чисел textarea в req.body.numbers. Расширенное значение, закодированное в urlencode * true extended: true not extended: false

0 голосов
/ 21 июня 2019
  1. Вы должны использовать <form>
  2. Вам также нужна кнопка для отправки формы.
  3. Вы можете поймать значение <textarea> или <input> с помощью express и body-parser .

const express = require("express");
const app = express();
const bodyParser = require("body-parser");

const port = 3000;

app.use(bodyParser.urlencoded({extended: false}));

app.post("/link", (req,res) => {
  console.log(req.body.numbers);
  // body came with body-parser
  // numbers is name of textarea
});

// req is request and res is response

app.listen(port, () => {
  console.log("server launched");
});
<h4>Mobile Numbers</h4>

<form action="/link" method="POST">
  <textarea id="numbers" class="number-area" name="numbers"></textarea>
  <button type="submit">Submit</button>
</form>
...