Django III에서 다루게 될 내용은 다음과 같습니다.
4-1 Django custom user profile
4-2 User-submitted content
4-3 Finishing touches
4-2 User-submitted content
(1) Creating a vote model
Vote model을 models.py에 추가
다음과 같이 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/48b99/48b99d9a929eec79ae6ba479d44f27aea636b02d" alt=""
Migrations 수행
다음 명령을 수행합니다.
>python manage.py makemigrations
>python manage.py migrate
Vote model을 폼에 연결
다음과 같이 코드를 추가합니다.
mysite > main > forms.py
data:image/s3,"s3://crabby-images/7ac6b/7ac6bd9e1791ca638e81ab96f4762f24327a4967" alt=""
data:image/s3,"s3://crabby-images/74741/7474110a851abaec2a7e01e1bc49aa13716768ae" alt=""
VoteForm을 product 함수에 추가
다음과 같이 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/652fd/652fd1fe46f7f9807a00ed48cb691bad4060a899" alt=""
data:image/s3,"s3://crabby-images/99640/99640c84f431102cee2480c170c5db41c4bb1818" alt=""
(2) Adding the vote form to the products page
Bootstrap collapse를 product.html에 추가
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > products.html
data:image/s3,"s3://crabby-images/de312/de312e40e966dacd88fab75b6296a81f4fba1d61" alt=""
data:image/s3,"s3://crabby-images/87d62/87d6287be645285d323da4cf30832c50ba6bb297" alt=""
script를 product.html에 추가
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > products.html
data:image/s3,"s3://crabby-images/d0738/d073857619c6d0900d41caff2c293d9f6eeb0c8c" alt=""
style를 products.html에 추가
data:image/s3,"s3://crabby-images/a58cd/a58cd080e4f71f921817bd1b3d13c458ccd5c47f" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/a028f/a028fbfb7efceddd684c0b3cc5191f2f98e1740a" alt=""
(3) Handling the vote form submission
views.py에 product 기능 업데이트
다음과 같이 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/89cf9/89cf938f0dda4d0c656fccbdb1c0382c1f269817" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/10d70/10d70aab4f49d7ae6c7489bd25c8c48b88597c52" alt=""
(4) Displaying the product scores
models.py에 Product model 업데이트
다음과 같이 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/75cdb/75cdb38b7dfbdc9b6a632cea3456408d27546a2d" alt=""
Function을 Vote 모델에 추가
다음과 같이 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/98835/9883551e7c88a881eb82be93713c4afd8e851943" alt=""
data:image/s3,"s3://crabby-images/62987/62987b47f582d7e584440d2aa9471c0dc0f331c3" alt=""
Migrations 수행
다음 명령을 수행합니다.
>python manage.py makemigrations
>python manage.py migrate
views.py에 products view 업데이트
다음과 같이 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/836f7/836f749f07f28d542ff8b66ed527c1c10dbc8376" alt=""
products.html에서 products에 user score 추가
다음과 같이 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/09da7/09da7a93e4aa8ab7ccd422686e6294569061ee63" alt=""
home.html에서 products에 user score 추가
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/17010/17010b18a38c15720268d6b90ce0b236c97a32aa" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/de343/de343c23a2e7ad2f885dcaad29cbf0e83494e018" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/701ad/701ad7d7ab70bdb549f5f68db4e90846950f2c46" alt=""