Django I에서 다루게 될 내용은 다음과 같습니다.
2-1 Django installation and configuration
2-2 Django overview and debugging
2-3 Django + Bootstrap
2-4 Django functionality I
2-5 Django functionality II
이번에는 Django functionality I 입니다.
2-4 Django functionality I
(1) Adding Bootstrap cards
home.html에 Bootstrap card 추가
다음과 같이 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/52b60/52b60b8b65a0dc9a0ee8699567f7601b6415001f" alt=""
다음과 같이 Bootstrap card 코드를 추가합니다.
data:image/s3,"s3://crabby-images/43e63/43e63e1cab5e2a51ec9b285241777fab7ebd2f23" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/7f2b6/7f2b68b8be7a4c99551d75b649e22566d60bed3f" alt=""
(2) Creating a Django model
models.py 파일에 Product 모델 추가
다음과 같이 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/e7aba/e7aba03677329687db37e63cb00beca93c19993e" alt=""
models.py에 미디어 업로드 추가
다음과 같이 코드를 추가합니다.
data:image/s3,"s3://crabby-images/b6c5c/b6c5c30bde5e1b431eb5d3ef9daccebb7ebc1da7" alt=""
admin display name 변경
다음과 같이 코드를 추가합니다.
mysite > main > models.py
data:image/s3,"s3://crabby-images/64f32/64f328c9088fa88289a0c903440acdcf34343376" alt=""
settings.py에 media folder url 추가
다음과 같이 코드를 추가합니다.
data:image/s3,"s3://crabby-images/3072c/3072c91d4af404a71696e6be50d18942cfde33c8" alt=""
urls.py에 media folder url 추가
다음과 같이 코드를 추가합니다.
mysite > mysite > urls.py
data:image/s3,"s3://crabby-images/16b7c/16b7c660d5964eb5462d70a7ff74cfc3254f1870" alt=""
새 모델을 database에 적용
다음 명령어를 수행합니다.
>python manage.py makemigrations
>python manage.py migrate
data:image/s3,"s3://crabby-images/bcfbe/bcfbeec712b220816e4a6a73c14febb535fa271d" alt=""
admin.py에 모델 등록
다음과 같이 코드를 추가합니다.
mysite > main > admin.py
data:image/s3,"s3://crabby-images/4498f/4498f09ee95f99a9a01d3a91e4b9c0b74ac73848" alt=""
Django 관리자 로그인
슈퍼 관리자로 로그인하면 다음 그림처럼 모델이 등록된 것을 볼 수 있습니다.
data:image/s3,"s3://crabby-images/afed0/afed04f4ed02ff0c1e00ca82f140fd84f5cd3402" alt=""
Django admin에 Product 정보 등록
관리자 화면에서 Product를 등록합니다.
data:image/s3,"s3://crabby-images/45afc/45afc0c10e27c7a132864bf80e874116debd9e0a" alt=""
총 4개 Product를 등록합니다.
Product name | Jaybird X3 | Apple Airpods | ASTRO A40 | Beats Studio3 Wireless |
Product type | Wireless Earphones | Wireless Earbuds | Gaming Headset | On-Ear Headphones |
Product description | Sports earbuds with a secure fit for athletic performance | Active noise cancellation and quick access to voice assistant | Adjustable & lightweight with removable mic | Up to 22 hour battery life, noise cancelling headphones |
Affiliate url | ||||
Product image | jaybird-x3.jpg | apple-airpods.jpg | astro-a40.jpg | beats-studio3.jpg |
data:image/s3,"s3://crabby-images/5873a/5873a701ac53ce51353450fddb667e2443e5b750" alt=""
(4) Displaying information with DTL
Product 모델을 출력하기 위한 views.py 설정
다음 코드를 추가합니다.
mysite > main > views.py
data:image/s3,"s3://crabby-images/78b65/78b650c8bdf703f8bddedb14dd0d8349a4f13258" alt=""
Product를 출력하기 위한 home.html 수정
다음 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/3e188/3e1886415c825539a1d7e8bdfc83068be9dd3dff" alt=""
home.html 파일에 Product 필드 추가
다음 코드를 추가합니다.
mysite > main > templates > main > home.html
data:image/s3,"s3://crabby-images/ba3dc/ba3dc8257cbf49e229566b60796ae0f35df15bba" alt=""
브라우저에서 확인해 봅니다.
data:image/s3,"s3://crabby-images/79828/798289e70c47d7019b2361439bf452f988969c5e" alt=""