| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 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 | 
                            Tags
                            
                        
                          
                          - Machine Learning
 - ChatGPT
 - deep learning
 - LG Aimers
 - LG
 - OpenAI
 - 해커톤
 - AI
 - GPT-4
 - 회귀
 - LLM
 - gpt
 - PCA
 - 딥러닝
 - Classification
 - LG Aimers 4th
 - supervised learning
 - 오블완
 - regression
 - 분류
 - 티스토리챌린지
 - 지도학습
 - 머신러닝
 
                            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로 둘을 나눌 수 있음




728x90
    
    
  반응형
    
    
    
  '대딩코딩 > 웹개발 스터디' 카테고리의 다른 글
| [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 |