在 HTML 网站上显示 Node.js MySQL 表格

6

我是node.js的新手,想在一个html页面上显示一个简单的表格。这个表格应该用从mysql select中获取的数据填充(例如:select * from testtable)。

但我真的不知道该怎么做。对于有PHP背景的人来说,我该如何在nodejs中在HTML中显示一些SQL内容?我知道git mysql nodejs wiki,但它根本没有帮助,因为它只涉及到获取数据而不是在网页上显示数据。

在nodeJS中做这样的事情的最佳实践是什么?有没有易于理解的简单方法,还是我应该继续使用PHP?我真的很喜欢node.js的想法,但是开始就像爬滑坡一样困难。

我还买了一本关于它的书,但是这本书从来没有深入到express中(因为这将是太多的信息...)。所以我知道express、pug、serve-static,我能够提供一个简单的html。但仅此而已,没有CRUD或REST,而我花了50欧元却什么都没学到。

编辑: 我需要使用API吗?或者使用Angular.js可能是正确的方法吗?

编辑2:

C:\Users\user\node_test\CRUD2>node app.js
module.js:327
throw err;
^

Error: Cannot find module './routes'

at Function.Module._resolveFilename (module.js:325:15)

at Function.Module._load (module.js:276:25)

at Module.require (module.js:353:17)

at require (internal/module.js:12:17)

at Object.<anonymous> (C:\Users\user\node_test\CRUD2\app.js:2:14)
at Module._compile (module.js:409:26)

at Object.Module._extensions..js (module.js:416:10)

at Module.load (module.js:343:32)

at Function.Module._load (module.js:300:12)

at Function.Module.runMain (module.js:441:10)

编辑3:

C:\Users\user\node_test\CRUD2>node app.js
Express server listening on port 4300
C:\Users\user\node_test\CRUD2\routes\testtable.js:4
var query = connection.query('SELECT * FROM testtable',function(err,rows){
                    ^

TypeError: Cannot read property 'query' of undefined
at C:\Users\user\node_test\CRUD2\routes\testtable.js:4:29
at C:\Users\user\node_test\CRUD2\node_modules\express-myconnection\lib\express-myconnection.js:87:41
at Pool.<anonymous> (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\Pool.js:47:16)
at Handshake.Sequence.end (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\protocol\sequences\Sequence.js:78:24)
at Handshake.ErrorPacket (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\protocol\sequences\Handshake.js:101:8)
at Protocol._parsePacket (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\protocol\Protocol.js:205:24)
at Parser.write (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\protocol\Parser.js:62:12)
at Protocol.write (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\protocol\Protocol.js:37:16)
at Socket.<anonymous> (C:\Users\user\node_test\CRUD2\node_modules\mysql\lib\Connection.js:73:28)
at emitOne (events.js:77:13)
1个回答

8

这里是一个例子:

app.js

var express = require('express');
var routes = require('./routes');
var http = require('http');
var path = require('path');

//Including controller/dao for testtable
var testtable = require('./routes/testtable'); 
var app = express();
var connection  = require('express-myconnection'); 
var mysql = require('mysql');
// all environments
app.set('port', process.env.PORT || 4300);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(express.static(path.join(__dirname, 'public')));
// development only
if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.use(
    connection(mysql,{

        host: 'localhost',
        user: 'your_user',
        password : 'your_password',
        port : 3306, //port mysql
        database:'dbname'
},'pool')
);
app.get('/testtable', testtable.list);
app.use(app.router);
http.createServer(app).listen(app.get('port'), function(){
    console.log('Express server listening on port ' + app.get('port'));
});

routes/testtable.js

exports.list = function(req, res){

  req.getConnection(function(err,connection){   
      var query = connection.query('SELECT * FROM testtable',function(err,rows){
        if(err)
          console.log("Error Selecting : %s ",err );

        res.render('testtable',{page_title:"Test Table",data:rows});
      });
  });
};

views/testtable.ejs

<html><body>
<table border="1" cellpadding="7" cellspacing="7">
  <tr>
    <th width="50px">No</th>
    <th>Field 1</th>
    <th>Field 2</th>
    <th>Field 3</th>
  </tr>
  <% if(data.length){ 
    for(var i = 0;i < data.length;i++) { %>
  <tr>
    <td><%=(i+1)%></td>
    <td><%=data[i].field1%></td>
    <td><%=data[i].field2%></td>
    <td><%=data[i].field3%></td>
  </tr>
  <% }
  }else{ %>
  <tr>
    <td colspan="3">No user</td>
  </tr>
<% } %>
</table>
</body></html>

要运行此“项目”,您需要安装一些节点模块,您可以在根目录中创建一个名为“package.json”的文件:
{
  "name": "application-name",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node app.js"
  },
  "dependencies": {
    "ejs": "^1.0.0",
    "express": "3.5.1",
    "express-myconnection": "1.0.4",
    "jade": "*",
    "mysql": "2.2.0"
  }
}

然后在项目根目录下调用"npm install"。

希望这可以帮助你。


这真的很棒!但是当我尝试启动app.js时出了些问题,报错信息为“Error: Cannot find module './routes'”,错误来源于“module.js:327”。我将app.js中的require更改为以下内容以获取路由:var routes = require('./routes/testtable');,但现在我得到了一个新的错误:“throw new Error('Most middleware (like ' + name + ') is no longer bundled with Express”。 - user3772108
似乎现在日志记录器变成morgan了,而且json也不再包含在express中了。谢谢你的例子和时间,我会尝试用这个创建我的应用程序。 - user3772108
我按照你告诉我的方法,使用package.json和npm安装了所有内容。不幸的是,我仍然遇到了我在原帖中更新过的错误。我缺少什么或者做错了什么? - user3772108
SQL查询语句 select * from db.testtable; 是有效的。我已经在testtable.js中将其更改为此查询语句,但仍然没有成功。服务器仍然崩溃。 - user3772108
1
尝试在“/node_modules/express-myconnection/examples/single”下运行示例,您需要使用Windows的SET或LINUX的EXPORT设置环境变量。并设置DB_HOST='localhost' DB_USER='user' DB_PASSWORD='pwd'和DB_DATABASE='yourdb',现在在浏览器中调用http://localhost:3000/,它是否有效? - Alessandro
显示剩余11条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接