Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- MongoDB
- 네트워크
- 명령어
- Docker-compose
- 실습
- nodejs
- dockerfile
- node.js
- OpenStack
- gns3
- 쿠버네티스
- 도커
- git
- RAID
- Docker Swarm
- 클라우드
- PAT
- 개념
- IaaS
- 이론
- mysql
- kubernetes
- Javascript
- worker
- express
- network
- RAPA
- docker
- PaaS
- 용어정리
Archives
- Today
- Total
융융이'Blog
Nodejs, express, MongDB를 이용한 CRUD(6)_Controller_like.js 본문
controller/like.js
module.exports = {
toggle_like: async(req, res) => {
const user = req.body.user;
const { board_id } = req.params;
let result = {};
const is_liked = await Like.findOne({$and: [{user: user}, {board: board_id}]});
// 해당 게시물에 좋아요 일때
if(is_liked){
await Like.findByIdAndDelete(is_liked);
result = {data : false}
}
// 해당 게시물에 좋아요 아닐때
else{
//creat에 save명령어도 같이 실행된다.
await Like.create({
user: user,
board: board_id
});
// await liking.save();
result = {data : true}
}
return res.json(result);
}
}
좋아요 Toggle
좋아요를 눌렀을 때, 만약 사용자가 해당 게시물에 좋아요를 안눌렀다면 Like모델에 M:N 형태로 값을 저장하게 된다. 만약 좋아요가 눌렀던 게시물이면 Like테이블에서 해당하는 값을 찾아서 삭제를 하는 식으로 Toggle 기능을 구현을 하였다.
'2022이전 > node.js' 카테고리의 다른 글
노드 내장 객체 알아보기 (0) | 2020.01.13 |
---|---|
Nodejs, express, MongDB를 이용한 CRUD(7)_미들웨어 (0) | 2020.01.12 |
Nodejs, express, MongDB를 이용한 CRUD(5)_Controller_comment.js (0) | 2020.01.12 |
Nodejs, express, MongDB를 이용한 CRUD(4)_Controller_board.js (0) | 2020.01.12 |
Nodejs, express, MongDB를 이용한 CRUD(3)_Controller_user.js (0) | 2020.01.12 |