javascript - 在node js中将html表数据插入mysql数据库

标签 javascript html mysql node.js ejs

我正在尝试从 html 表中检索数据并将其插入 MySQL 数据库中。我已经能够执行相反的操作,即从数据库中检索信息并使用 ejs 模板将其显示在同一个表中。我还可以将原始/JSON 数据插入 MySQL,但我无法从同一个表中提取数据,因为我无法从服务器端引用该表(与正文解析器处理表单数据的方式相同)。

我在网上搜索过,所有教程都只是使用 json 数据插入数据库,没有人首先从 html 表中检索数据。

通过下面的代码,我可以使用纯 JavaScript 循环遍历表数据。

var table = document.getElementById('vehiclesTB');
for (var i = 1; i < table.rows.length; i++) {
  if (table.rows[i].cells.length) {
    var vehicleTag = (table.rows[i].cells[0].textContent.trim());    
  }
}

如何将检索数据从 html 表传递到我的 Controller (服务器端)?我无法直接从我的服务器文件 (app.js) 引用 html 表。

我的 app.js 文件:

var express = require('express')
  , routes = require('./routes')
  , controls = require('./routes/controls')
  , http = require('http')
  , path = require('path');
var app = express();
var mysql = require('mysql');
var bodyParser =require("body-parser");
var pool = mysql.createConnection({
    connectionLimit: 100,
    host: 'localhost',
    database: 'vehicluster',
    user: 'motor',
    password: '',
    debug: false  
});

pool.connect();



// all environments
app.set('port', process.env.PORT || 8080);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.use(express.static(path.join(__dirname, 'public')));

app.post('/vehicle', controls.vehicle);
//Middleware
app.listen(8080)

我的controls.js 文件。

exports.vehicle = function(req, res){                   
var table = document.getElementById('vehiclesTB');//how to read this 
table in ejs
for (var i = 1; i < table.rows.length; i++) {
if (table.rows[i].cells.length) {
var vehicleTag = (table.rows[i].cells[0].textContent.trim());
var vehicleMake = (table.rows[i].cells[1].textContent.trim());
var vehicleModel = (table.rows[i].cells[2].textContent.trim());
var price = (table.rows[i].cells[3].textContent.trim());
var quantity = (table.rows[i].cells[4].textContent.trim());                
     }
}

var sql = 'insert into Vehicle(make, model, price, quantity) values 
(?,?,?,?,?)';
pool.query(sql,[vehicleMake, vehicleModel, price, quantity], 
(err,data)=>{
if(err){
    console.log(err);            
    return
 }else{
    console.log(data);                        
     }      
 };

HTML表格显示相关项目(表格),将表格数据放入mysql数据库中。我已经可以检索到表:

<div style="overflow-x: auto;">                       
    <table id="customers">
        <tbody id="mytbody">
            <tr>                                  
                <th>Make</th> 
                <th>Model</th>
                <th>price</th>
                <th>quantity</th>                                                                   
            </tr>
            <tr>
                <th>toyota</th> 
                <th>camry</th>
                <th>200</th>
                <th>5</th>                                     
            </tr>
            <tr>
                <th>honda</th> 
                <th>civic</th>
                <th>400</th>
                <th>7</th>                                     
            </tr>
        </tbody>
    </table>                            
</div>

正如您所料,我收到错误,getElementById 是客户端,空值等,数据库未更新。大多数在线教程都显示相反的内容,即将数据库值插入到 html 表中,而不是相反。任何有关真实表格示例/路线的帮助将不胜感激。

最佳答案

如果您需要在服务器上提供客户端 HTML 表,那么您需要在服务器上添加 ajax 端点和代码来发送 HTML 数据(请参阅 axios 库)。

我不确定您的用例,因为自从您渲染以来,客户端的数据似乎应该已经在服务器上可用。它可能不是 HTML 格式,但数据应该存在于其中。当然,除非您从其他来源获取 HTML 表(或者这可能只是 HTML 解析的练习??)。

<小时/>

这里更新了如何使用 axios。但请注意,您仍然需要研究该库以了解如何处理错误,或者即使您在成功后需要执行其他操作。

在你的前端:

var table = document.getElementById('vehiclesTB');
var postBody = [];
for (var i = 1; i < table.rows.length; i++) {
  if (table.rows[i].cells.length) {
    var vehicle = {
      vehicleTag: (table.rows[i].cells[0].textContent.trim())
      vehicleMake: (table.rows[i].cells[1].textContent.trim()),
      vehicleModel: (table.rows[i].cells[2].textContent.trim()),
      price: (table.rows[i].cells[3].textContent.trim()),
      quantity: (table.rows[i].cells[4].textContent.trim())
    }
    postBody.push(vehicle);
  }

}

axios({ // should add error handling as appropriate
  method: 'post',
  url: '/vehicle',
  data: postBody
});

然后在服务器端修改controls.js:

exports.vehicle = function(req, res) {
  var table = req.body; // assumes you have used bodyparser middleware to parse JSON into an object
  for (var i = 1; i < table.length; i++) {
    var vehicle = table[i];
    var sql = 'insert into Vehicle(make, model, price, quantity) values ( ? , ? , ? , ? , ? )';
    pool.query(sql, [vehicle.vehicleMake, vehicle.vehicleModel, vehicle.price, vehicle.quantity],
      (err, data) => {
        if (err) {
          console.log(err);
          return
        } else {
          console.log(data);
        }
      });
  }
};

此外,我建议您查看 Array.forEach 来查找数组,而不是您正在使用的 for 循环方法(请参阅 MDN documentation)

关于javascript - 在node js中将html表数据插入mysql数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57529958/

相关文章:

javascript - 我需要在设置跟踪代码 piwik 中包含所有方法吗?

javascript - onclick 刷新但不是从缓存中刷新?

html - 如何获得这种水平滚动?

javascript - "modal"不被 Angular 识别为元素

mysql - 将唯一的选择值分配给唯一的一个变量

将 Razor 变量分配给 Javascript 变量时出现 Javascript 语法错误

javascript - 如何知道图像是否无法在 javascript 中加载?

mysql - 如何将此 ActiveRecord 查询重写为 MySQL?

php - 在 PHP/HTML 中格式化 MySQL 查询

javascript - 如何使用 AngularJs 构建一个小部件以嵌入第三方网站?