Django III에서 다루게 될 내용은 다음과 같습니다.
4-1 Django custom user profile
4-2 User-submitted content
4-3 Finishing touches
4-1 Django custom user profile
(1) Creating a user page
user.html 파일 생성
다음과 같이 파일을 생성합니다.
mysite > main > templates > main > (New File) user.html
user.html 파일 편집
다음과 같이 파일을 편집합니다.
mysite > main > templates > main > user.html
data:image/s3,"s3://crabby-images/1edb7/1edb76a1aeb247028bbea0765e86b53edd3c49f0" alt=""
(2) Creating a profile model
models.py에 profile 모델 생성
다음 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/c2a9a/c2a9ab800f870c5b4015055709e21c06e38332e2" alt=""
data:image/s3,"s3://crabby-images/87f56/87f56bbae950f77d35283060fdbfb039ea636bf5" alt=""
Django user 생성 및 저장 함수 오버라이트(overwrite)
다음 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/b4712/b471204834fae6395b2f18cd9a6ad997f4a6df9f" alt=""
data:image/s3,"s3://crabby-images/b2434/b2434c74421e8e37876af58a3378df69f39fac03" alt=""
Migrations 수행
다음 명령을 수행합니다.
>python manage.py makemigrations
>python manage.py migrate
기존 유저를 위한 프로필 생성
다음 명령을 수행합니다.
>python manage shell
data:image/s3,"s3://crabby-images/c2ffd/c2ffdf3b325ba8c16765a9339b02b266e119bc56" alt=""
위와 같이 오류가 나면 (TAB)을 누르고 Profile.objects.create(user=user)을 입력하면 정상 동작합니다.
User 링크를 navbar.html에 추가
다음 코드를 추가합니다.
mysite > main > templates > main > includes > navbar.html
data:image/s3,"s3://crabby-images/fefd9/fefd9cc51e06f9d4a0326703eace7b41b9e32d0a" alt=""
(3) Creating user and profile forms
forms.py에 user 폼 추가
다음 코드를 추가합니다.
mysite > main > forms.py
data:image/s3,"s3://crabby-images/642f8/642f8fd9285491419673bfa3f397936c725fb2c8" alt=""
forms.py에 profile 폼 추가
다음 코드를 추가합니다.
mysite > main > forms.py
data:image/s3,"s3://crabby-images/1a31e/1a31e106f900c24081372bf45d727f33cdc6e65b" alt=""
data:image/s3,"s3://crabby-images/4245a/4245a2a826092d50e259a6100c8958dc20aa13f0" alt=""
user.html을 usls.py에 추가
다음 코드를 추가합니다.
mysite > main > urls.py
data:image/s3,"s3://crabby-images/d5d60/d5d60241abbfcced2f23242792cb3aeba76ed61a" alt=""
Userpage 기능을 views.py에 추가
다음 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/9ddec/9ddecb84a20f49ba9b2d554d4a8d4ee2f76b7757" alt=""
data:image/s3,"s3://crabby-images/e971a/e971a98f90ac51f912e51a74ef7b367a4208030e" alt=""
변수들을 user.html에 추가
다음 코드를 추가합니다.
mysite > main > templates > main > user.html
data:image/s3,"s3://crabby-images/3f704/3f704d569f6205f2edb8bfe57ee202a63f383553" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/bb1fd/bb1fd2280b409ed851ff5f394d08a50ee34dd0d7" alt=""
UserForm을 user.html로 연결
다음 코드를 추가합니다.
mysite > main > templates > main > user.html
data:image/s3,"s3://crabby-images/de11e/de11e9ca3526f701a6b1be992e352df6d8aeb831" alt=""
다음과 같이 Modal 팝업 창 코드를 추가합니다.
data:image/s3,"s3://crabby-images/8bed4/8bed4eb5ead92e99303ff39fc0d8ecaff5f3da73" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/49018/49018709d4d11395df9a8e02b492421109c92a1b" alt=""
ProfileForm을 user.html로 연결
다음 코드를 추가합니다.
mysite > main > templates > main > user.html
data:image/s3,"s3://crabby-images/dd763/dd76359f1a1ff66220a349c9ea53129b71519a09" alt=""
Wishlist modal 추가
다음 코드를 추가합니다.
mysite > main > templates > main > user.html
data:image/s3,"s3://crabby-images/0f7bc/0f7bc09c5f085f56d49c0dae1dd8e3e47a5ef6c1" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/fcc08/fcc081fd8c8f030ce5067b77df2211195834a284" alt=""
(4) Using Bootstrap modals
User와 profile 폼 변화를 저장하기 위한 views.py 수정
다음 코드를 추가합니다.
mysite > main > views.html
data:image/s3,"s3://crabby-images/eb01c/eb01c3be0a075645730bb47fd6ac72a4e390cdde" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/48430/48430e6f1e6015668b6b4100ab592b5e195b7da8" alt=""
(5) Adding a wishlist button to the products
Wishlist 버튼을 products.html에 추가
다음 코드를 추가합니다.
mysite > main > templates > main > products.html
data:image/s3,"s3://crabby-images/03ace/03ace19c16f92b1fca49a802287e525ca11ad4b8" alt=""
views.py에 있는 product 코드 업데이트
다음과 같이 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/eb806/eb806775b38cc533b3e461d97789e86ff9a1e3fa" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/c24ce/c24cee8a0bf6cd4cbd1d4e5d0057f77eed893eb6" alt=""
data:image/s3,"s3://crabby-images/513e4/513e48da4cb937b014e9eb20cbcba369c22dc5c7" alt=""
home.html에서 wishlist 버튼을 product에 추가
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/53adf/53adfa2a5b15c843eb832dca6f800179ca1369d5" alt=""
wishlist 기능 추가 코드를 위한 homepage view 업데이트
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/fa1a4/fa1a438516ea30315aad4c48c9d26a9b59c31ec6" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/405a9/405a998228926457fd856dea3ae1c61ff90af860" alt=""
data:image/s3,"s3://crabby-images/c5d6a/c5d6a72ff506cf13ac18c0c202a16442cad4780e" alt=""
로그인 한 사용자에게 특정한 CTA 버튼 연결
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/9aeaf/9aeaf495dd9dfa9b545282aa398ae2edeb2989a1" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/9b2b5/9b2b59c4ea93a7925ea3491ba333646f504b3bf7" alt=""
data:image/s3,"s3://crabby-images/496c1/496c1bcb8026171dd055fc2e22aec36abd2f9476" alt=""