seb*_*res 0 mysql node.js express angular
嗨,我对此感到存在危机。
任何人都可以举例说明如何使用节点/快速后端将我的 Angular(我使用的是 angular 6)前端与MySQL数据库(请不是 NoSQL 示例,有很多)连接?
我周末一直在阅读,搜索 google、stack、youtube 等,并且有很多关于某些事情的例子,但还不足以让我理解。我无法想象的是如何在我的前端按下按钮,调用我的数据库并使其出现在我的网站中(基本上所有 CRUD 操作)。
我需要硬编码。我没有我的任何代码,因为我什至无法想象如何在我的 app.js 中连接我的角度组件中的按钮以对 mysql 数据库进行 crud 操作。我真的很困惑。
假设我将 phpmyadmin 用于 MySQL,并且有一个名为 的数据库users,其中 1 列的user_name值为Aquiles。有了这个,我想阅读,更新,删除。
其他帖子的链接(虽然我几乎搜索了所有帖子)、视频、教程,都是受欢迎的。
感谢您的时间,问候。
回答我自己的问题,如果有任何灵魂因此而感到绝望,就在这里。
CREATE TABLE IF NOT EXISTS 'tasks' (
'id' int(11) NOT NULL,
'task' varchar(200) NOT NULL,
'status' tinyint(1) NOT NULL DEFAULT '1',
'created_at' datetime NOT NULL DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
ALTER TABLE 'tasks' ADD PRIMARY KEY ('id');
ALTER TABLE 'tasks' MODIFY 'id' int(11) NOT NULL AUTO_INCREMENT;
INSERT INTO 'tasks' ('id', 'task', 'status', 'created_at') VALUES
(1, 'Find bugs', 1, '2016-04-10 23:50:40'),
(2, 'Review code', 1, '2016-04-10 23:50:40'),
(3, 'Fix bugs', 1, '2016-04-10 23:50:40'),
(4, 'Refactor Code', 1, '2016-04-10 23:50:40'),
(5, 'Push to prod', 1, '2016-04-10 23:50:50');
Run Code Online (Sandbox Code Playgroud)
我从阅读这篇文章Creating a RESTful API with Express js, Node js/MySQl - Arjun 中得到了这个
const express = require('express');
const mysql = require('mysql');
const bodyParser = require('body-parser');
const app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
extended: true
}));
// Connect my db
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : '',
database : 'dbName'
});
connection.connect(function(err) {
if (err) {
console.error('error connecting: ' + err.stack);
return;
}
console.log('connected as id ' + connection.threadId);
});
app.get('/', function (req, res) {
res.send('Hello World!');
});
// Port that will be listened
app.listen(3000, function () {
console.log('Example app listening on port 3000!');
});
// the query
querie = 'SELECT * FROM tasks';
**THIS IS THE API ENDPOINT FOR THE GET REQUESTS**
app.get('/todos', function (req, res) {
connection.query(querie, function (error, results, fields) {
if (error) throw error;
return res.send({ error: false, data: results, message: 'Todos list.' });
});
});
Run Code Online (Sandbox Code Playgroud)
该app.component.html文件
<button
(click)="getData()">GET Profile
</button>
Run Code Online (Sandbox Code Playgroud)
import { Component } from '@angular/core';
import { HttpClient } from "@angular/common/http";
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
constructor (private httpClient:HttpClient){ }
getData(){
this.httpClient.get('/api/todos')
.subscribe(
(data:any[]) => {
console.log(data);
}
)
}
}
Run Code Online (Sandbox Code Playgroud)
现在您需要在一个终端窗口中启动您的 angular 项目,而在另一个终端窗口中启动服务器。一个将在端口 4200(角度)中,服务器将在 localhost:3000 中,就像我们在app.js 中配置的那样。
问题是,当您通过端口 :4200 从前端发出 get 请求时,会导致错误。它说您的请求正在低谷http://localhost:4200/localhost:3000或与此非常相似(很晚了,我没有记录确切的错误,抱歉)。因此,经过一些研究,我遇到了这篇文章https://medium.freecodecamp.org/the-best-ways-to-connect-to-the-server-using-angular-cli-b0c6b699716c并使用了“代理方法”。
瞧,在我的 javascript 控制台中有一个数组,其中包含我的数据库中的所有内容。
阅读这篇文章可以更清楚地了解一切。这是一个非常糟糕的解释(对于高级解释)。
问候。
| 归档时间: |
|
| 查看次数: |
2183 次 |
| 最近记录: |