data:image/s3,"s3://crabby-images/1049a/1049a500ea9352191afcad41a33a0b3648baa0a3" alt="토글로 좋아요 표시하기"
1. 토글로 하기
- id를 안주면 id를 못찾는데 어떻게 바꿀 수 있을까?
e.타겟을 찾아서 하면 됨
- 이벤트를 찾아서 타겟을 받으면 DOM을 찾을 수 있음
<!DOCTYPE html> <html> <head> <title>Font Awesome 5 Icons</title> <meta name='viewport' content='width=device-width, initial-scale=1'> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css"> <style> .my-cursor { cursor: pointer; } .my-love { color: red; } </style> </head> <body> <i onclick="loveToggle(event)" class="fas fa-heart my-cursor"></i> <script> let check = -1; function loveToggle(e) { console.log(e.target); if (check == -1) { $(e.target).addClass("my-love"); } else { $(e.target).removeClass("my-love"); } check = check * -1; } </script> </body> </html>
data:image/s3,"s3://crabby-images/8499f/8499fcbff7e795e91c5300586d9c4518fa59e0b4" alt="notion image"
data:image/s3,"s3://crabby-images/7fd71/7fd7101d769c034c6bad798f8bc3fc815e1b0499" alt="notion image"
2. boolean으로 하기
- isLike : 전역변수
- isLike를 역치만 해주면 됨
<!DOCTYPE html> <html> <head> <title>Font Awesome 5 Icons</title> <meta name='viewport' content='width=device-width, initial-scale=1'> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css"> <style> .my-cursor { cursor: pointer; } .my-love { color: red; } </style> </head> <body> <i onclick="loveToggle(event)" class="fas fa-heart my-cursor"></i> <script> let isLike = false; function loveToggle(e) { console.log(e.target); if (isLike == true) { $(e.target).addClass("my-love"); } else { $(e.target).removeClass("my-love"); } isLike = !isLike; } </script> </body> </html>
data:image/s3,"s3://crabby-images/030dd/030dd206880c7ebcc95abd2aa04b79343bf46488" alt="notion image"
data:image/s3,"s3://crabby-images/0a88f/0a88fd7c3d4a4d148c1c25e8a89d94b67f473e69" alt="notion image"
3. 클래스를 넣다 뺏다 하기 / 이게 제일 좋음
<!DOCTYPE html> <html> <head> <title>Font Awesome 5 Icons</title> <meta name='viewport' content='width=device-width, initial-scale=1'> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css"> <style> .my-cursor { cursor: pointer; } .my-love { color: red; } </style> </head> <body> <i onclick="loveToggle(event)" class="fas fa-heart my-cursor"></i> <script> function loveToggle(e) { console.log(e); $(e.target).toggleClass("my-love"); } </script> </body> </html>
data:image/s3,"s3://crabby-images/e5f9e/e5f9e2ec3ee5eae5a9817c5171e7b7b0770a4fb5" alt="notion image"
data:image/s3,"s3://crabby-images/fa5d4/fa5d41783b9abc15b7e4ab2f07489c731f142703" alt="notion image"
- 클라이언트 사이드 랜더링 할 때 사용
무조건 사용하는 것은 아님
ex) 검색을 하다 좋아요를 누르면 검색 글자가 남아있음
ex) 휴대폰 인증하기
- 클릭해서 서버쪽으로 인서트하고 색깔이 있는 전체 페이지를 다운 받아도 됨
ex) 검색하다 좋아요를 누르면 검색 글자가 없어짐
4. onclick이 아닌 id 만들어서 해보기
- 이벤트를 받을 필요가 없음
<!DOCTYPE html> <html> 되게 티 <head> <title>Font Awesome 5 Icons</title> <meta name='viewport' content='width=device-width, initial-scale=1'> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css"> <style> .my-cursor { cursor: pointer; } .my-love { color: red; } </style> </head> <body> <i id="love-1" class="fas fa-heart my-cursor"></i> <script> $("#love-1").click(() => { $("#love-1").toggleClass("my-love"); }); </script> </body> </html>
data:image/s3,"s3://crabby-images/693ed/693ed93ee1829528754f621b86431c7336c4734b" alt="notion image"
data:image/s3,"s3://crabby-images/b437c/b437cf3a66fbe3ae75ce16c0a2420fcd6083d768" alt="notion image"
Share article