Easy to create blog site even for beginners
Development Preparation
- Figure-01: “Build virtual environment (line 1)” in any folder
- Figure-01: Virtual environment execution (When executed, “(myvenv)” appears at the leftmost position)
- Figure-02: Creating requirements.txt (describing packages required for development)
- Figure-02: Package installation (pip3 install -r requirements.txt)
data:image/s3,"s3://crabby-images/02e83/02e83824877c53ef3a290b2ca18abd11b74ec489" alt=""
data:image/s3,"s3://crabby-images/a52da/a52da174bf3ecc013d14499721bea98137938d36" alt=""
Create Project
data:image/s3,"s3://crabby-images/ffd30/ffd3005add6ad8ff835d3ebd58f06d8ea67daf4f" alt=""
data:image/s3,"s3://crabby-images/bf8ba/bf8ba66a3eb3b65ed0cb58df67a5deca14d8eca2" alt=""
data:image/s3,"s3://crabby-images/85d49/85d49cb12f6127985a4c59aa916ab78457c3450c" alt=""
data:image/s3,"s3://crabby-images/b9d2b/b9d2b917ef2f6ffa35b9e73c2dc90efe534f6ebe" alt=""
- Figure-03: Project Creation (“mysite . is an arbitrary name. Project name space period, which can be created directly under the directory)
- Figure-04: mysite -> setting.py to change settings (language and time zone)
- Figure-05: Migrate (database setup)
- Figure-06: Web server startup
- Figure-07: Access the URL and confirm Django installation
data:image/s3,"s3://crabby-images/ee9e6/ee9e65e4a3d0ff091b4fbc625ae7a683e485968f" alt=""
Create Application
- Figure-08: Application creation (“app” is an arbitrary name)
- Figure-09: mysite -> settings.py -> ‘widget_tweaks’, ‘app’, added
data:image/s3,"s3://crabby-images/3aeef/3aeef388f58e8a206c003694034173e64d38bd17" alt=""
data:image/s3,"s3://crabby-images/b15ff/b15ff193753ad1017f87a4e7a76fe08c2e389ddd" alt="Django-settings.py"
Model
- Figure-10: app -> models.py “class name: Post” is optional. author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE) *ForeignKey is linked to login linked to the user.
def str(self) allows you to define a name (string) to identify the data (records) in the model that will be displayed on the admin screen.
We have defined the title, text, and created_date fields in the Post model, and in def str(self) we return the title field
https://office54.net/python/django/model-str-self
data:image/s3,"s3://crabby-images/3c1dc/3c1dc3f0c517b3e7c8d5ed889f6a4517578c4a89" alt=""
Admin
data:image/s3,"s3://crabby-images/2d3bc/2d3bc4b09f60a178aaadbb7d149beaea4d233c84" alt=""
- Figure-11: Reflecting the model just created on the admin page: app -> admin.py
- Figure-12: Migration: python3 manage.py makemigrations (required when changing models)
- Figure-12: migrate: python3 manage.py migrate
- Figure-13: Creating an administrative user: python3 manage.py createsuperuser
- Figure-14: Web server startup: python3 manage.py runserver: Add /admin to the URL and log in with the username and password you just set.
- Figure-15, 16: Register a few dummies in “Post” (for layout confirmation)
data:image/s3,"s3://crabby-images/ccb16/ccb16bf7708c857fd09c6a14f7d8053b2ac72736" alt=""
data:image/s3,"s3://crabby-images/cda6d/cda6d422a8a7f9ee0f27e1bfa5c9071d84529b3f" alt=""
data:image/s3,"s3://crabby-images/5c975/5c975ce85f47dbfac13f044c0ef36afc5155ce23" alt=""
data:image/s3,"s3://crabby-images/98bb9/98bb907b15cfeb4c5b4a1d4e8045458c04ff2d3e" alt=""
data:image/s3,"s3://crabby-images/4eb2b/4eb2bcf1a12f630d339a1149dfb812fe6f799a6b" alt=""
Routing (URL)
There are two types of routing, one for projects and one for applications.
1. For projects (for management sites and applications)
2, For applications (URL and view matching)
- Figure-17: mysite -> urls.py (routing for project)
- Figure-18: app -> urls.py (creating and routing urls.py for the application)
data:image/s3,"s3://crabby-images/22501/22501685ea8ebbec2cf53b1e4d784aba1b5959d8" alt=""
data:image/s3,"s3://crabby-images/cb507/cb507651712fdf3d3c292858c0805b4200fe79c7" alt=""
views.py
- Figure-20: app -> views.py Edit: Importing View and Post
- Figure-20: Edit the top page view (index)
- Figure-20: get function, the first function called when the view is called
- Figure-20: Retrieving data from the Post model
- Figure-20: return -> pass data to the template specified by the render function
data:image/s3,"s3://crabby-images/8b4cc/8b4ccd09cabdf8a5aa3861c3a6fe7412b51648e2" alt=""
templates: base.html
Template converts data passed from view to HTML
data:image/s3,"s3://crabby-images/4a028/4a028057cacb5f8fd434857430896e43cfbe1905" alt=""
- Create “templates” folder in app
- Figure-21: Create “app” folder in templates
- Figure-21: Creating “base.html” in app -> templates -> app ->
- Copy and paste code from bootstrap
base.html often writes “headers, navigation, footers” that do not change dynamically
Django入門ブログ構築チュートリアル レッスン2
data:image/s3,"s3://crabby-images/b62af/b62af92b5d245f9bf00dddb822c51d6169c8f668" alt=""
templates: index.html
data:image/s3,"s3://crabby-images/fb400/fb400caf7cba4111d2b2b6d8e8510b000bd268c3" alt=""
- Figure-22: Loading base.html in the first line
- Figure-22: Loading postings with {% %}
- Figure-22: Reading an object specified by {{ }}
data:image/s3,"s3://crabby-images/a74a6/a74a62e05d330c3da0e65c8659c26387e034a7a5" alt=""
- Figure-23: Creating the sidebar
CSS
data:image/s3,"s3://crabby-images/83f16/83f16d2197ca1a1d03f51550eada393520a30215" alt=""
- Figure-24: app -> static folder creation -> css folder creation -> style.css file creation
- Figure-24: main { flex: 1; } to always place the footer at the bottom
- Figure-25: Adding stylesheet to base.html
data:image/s3,"s3://crabby-images/31e9a/31e9abcc1380f53f08d5b228f3bfe007a6af3679" alt=""
- Figure-26: Start the web server and click on the link
- Figure-27: Check the contents of the top page
data:image/s3,"s3://crabby-images/1b74c/1b74cbd1873d939f5ce7d4601cd7b3fdcc95697f" alt=""
data:image/s3,"s3://crabby-images/41470/414709c9833bf27ddb91ffc214fc1f28cf18207b" alt=""
Detail Page
data:image/s3,"s3://crabby-images/27d29/27d296b0d59bbeafa3ddebddc93beecdf9a59477" alt=""
- Figure-28: app -> urls.py with path for detail screen (post_detail)
- Figure-29: Add detail screen class to app -> views.py
- Figure-29: post_data = Post.objects.get(id=self.kwargs[‘pk’]) to get the data associated with the id (pk) of each post
- Figure-29: Calling the render function with return to pass data to the template
data:image/s3,"s3://crabby-images/7c1b5/7c1b5864b811c2b1887a0a8a63c61751bf5b64fb" alt=""
- Figure-30: app -> index.html Add link for more details
- Figure-31: app -> templates -> app -> post_detail.html created
data:image/s3,"s3://crabby-images/9385b/9385b19cc388890cfb5eebeb699af9f39c98ff24" alt=""
data:image/s3,"s3://crabby-images/a087b/a087b7e7081202db3f4123664fc1f7331e143c1d" alt=""
Upload Images
- Figure-32: “Pillow~=2.2.1” added to requirements.txt
- Figure-33: Installing with pip3 install -r requirements.txt
- Figure-34: Add image upload destination in mysite -> settings.py
data:image/s3,"s3://crabby-images/6336b/6336bc9d8f9f7f88602e11d80d44ecae0710b6ab" alt=""
data:image/s3,"s3://crabby-images/e3846/e3846b22e470ef2dee93fdf15594b9210277680a" alt=""
data:image/s3,"s3://crabby-images/916cc/916cc8a2f93de90b79031cb14fcf8b13119ca1c9" alt=""
- Figure-35: mysite -> append to urls.py
- Figure-35: if settings.DEBUG: … is for development environment *not when deploying
data:image/s3,"s3://crabby-images/fd9e6/fd9e6e38615d727fdb826e4b02b2088468239687" alt=""
- Figure-36: Append to class Post in app -> models.py
- After editing models.py, be sure to run “python3 manage.py makemigrations” and “python3 manage.py migrate
data:image/s3,"s3://crabby-images/80b23/80b23fc797f9cb3bb22cc6653ce44e494b9bbf29" alt=""
- Figure-37: Displaying images in index.html
- Figure-38: Displaying images in post_detail.html
- Both with {% if post.image %}, no error without image
- Figure-39: Editing style.css
data:image/s3,"s3://crabby-images/95e1d/95e1d3442bb35357c6bd9c38022581b07c97e06d" alt=""
data:image/s3,"s3://crabby-images/ea82d/ea82d0d6ed63468c4146b7d19805b69ac5e1d15b" alt=""
data:image/s3,"s3://crabby-images/5406e/5406ef386989dca696b0da2796ab71c67de7fe6d" alt=""