일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- PCA
- OpenAI
- deep learning
- 회귀
- 지도학습
- 딥러닝
- Machine Learning
- LG
- Classification
- ChatGPT
- 해커톤
- regression
- gpt
- LG Aimers
- 티스토리챌린지
- supervised learning
- GPT-4
- AI
- 오블완
- 머신러닝
- LLM
- LG Aimers 4th
- 분류
Archives
- Today
- Total
SYDev
[Express] 14. Create Comment POST 본문
Comment를 입력받고 웹페이지에 출력
파일명: main.js
const express = require('express');
const app = express();
const port = 3000;
const bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({ extended: false }))
app.use(bodyParser.json())
app.set('view engine', 'ejs');
app.set('views', 'views');
const expressLayouts = require('express-ejs-layouts');
app.use(expressLayouts);
app.set('layout', 'index.ejs');
app.set('layout extractStyles', true);
app.use(express.static('public'));
const homeController = require('./controllers/homeController.js');
app.get('/', homeController.getTopics);
//Routers
const topicRouter = require('./routers/topicRouter.js');
const commentRouter = require('./routers/commentRouter.js');
app.use('/topic', topicRouter);
app.use('/comment', commentRouter); //'/comment' 형태로 받는 건 전부 commentRouter가 처리
app.listen(port, () => {
console.log(`Example app listening on port ${port}`);
});
>> commentRouter로 이동
파일명: commentRouter.js
const express = require('express');
const router = express.Router();
const commentController = require('../controllers/commentController.js');
router.post('/create/:topic_id', commentController.createComment);
module.exports = router;
>> commentController로 이동
파일명: commentController.js
const commentModel = require('../models/commentModel.js');
module.exports = {
createComment: async (req, res) => {
const topicId = req.params.topic_id;
const newCommentData = req.body;
await commentModel.createComment(topicId, newCommentData);
res.redirect(`/topic/read/${topicId}`);
}
}
>> commentModel로 이동
파일명: commentModel.js
const db = require('../config/db.js');
module.exports = {
//DB에 comment 정보 추가
createComment: async (topicId, newCommentData) => {
const query = 'INSERT INTO Comments(username, content, topic_id) VALUES(?, ?, ?);';
await db.query(query, [newCommentData.username, newCommentData.content, topicId]);
},
//DB에서 comment 정보 read
getComments: async (topicId) => {
const query = 'SELECT * FROM Comments WHERE topic_id=?;';
const comments = await db.query(query, [topicId]);
return comments[0];
}
}
파일명: topic.ejs
<link rel="stylesheet" href="/css/input.css">
<h1><%= topic.title %></h1>
<p><%= topic.content %></p>
<form action="/topic/delete/<%= topic.topic_id %>" method="post">
<button>Delete</button>
<a href="/topic/update/<%= topic.topic_id %>">Update</a>
</form>
<div class="comment-container">
<% for(let comment of comments) { %>
<div class="comment-div">
<div>
<p><b><%= comment.username %></b></p>
<p><%= comment.content %></p>
</div>
<form action="/comment/delete/<%= comment.comment_id %>">
<button>Delete</button>
</form>
</div>
<% } %>
</div>
<form action="/comment/create/<%= topic.topic_id %>" method="post">
<input type="text" name="username" class="input-text" placeholder="username...">
<textarea name="content" id="" class="input-textarea" cols="30" rows="3" placeholder="content..."></textarea>
<button>Submit</button>
</form>
>> class: comment-div, comment-container에는 입력된 comment 정보 출력, 삭제 정보와는 각각 div, form 태그로 나눠짐
>> class: input-text, 아래에는 comment create
파일명: input.css
.input-text,
.input-textarea {
display: block;
margin: 1rem;
}
.comment-div {
margin: 1rem;
padding: 1rem 3rem;
border: 2px solid gray;
border-radius: 3rem;
display: flex;
flex-direction: row;
justify-content: space-between;
}
>> div에는 comment 내용, form에는 delte가 포함돼있기 때문에 distplay: flex로 둘을 나눌 수 있음
'대딩코딩 > 웹개발 스터디' 카테고리의 다른 글
[Express] 16. Create Comment Fetch (0) | 2023.12.04 |
---|---|
[Express] 15. Delete Comment POST (0) | 2023.12.01 |
[Express] 13. Routing (0) | 2023.12.01 |
[Express] 12. Update Topic POST (0) | 2023.12.01 |
[Express] 11. Delete Topic POST (0) | 2023.12.01 |