Skip to content

Djangoでウェブアプリを作る(11) – オーバービュー

前回の記事:
Djangoでウェブアプリを作る(10)

今回参照する公式チュートリアル:
https://docs.djangoproject.com/ja/3.2/intro/tutorial03

前回まではデータベース周りの設定を行ってきたが、今回はインターフェースの部分を作るようだ。

ウェブアプリというのは、インターフェースの設計を先にした方がいいような気もするが・・・

データベースの設計を先にするのが普通なのだろうか?

スポンサードリンク

オーバービュー

ビューとは、Django のアプリケーションにおいて特定の機能を提供するウェブページの「型 (type)」であり、各々のテンプレートを持っています・・・

いちいち表現が難しいな・・・ただの表示画面やろ?

URLパターンは、URLを単に一般化したものです。たとえば、/newsarchive/<year>/<month>/ などです。

えーっと、変数でパスを構成するみたいな・・?

URLからビューを得るために、Djangoは「URLconf」と呼ばれているものを使います。URLconfはURLパターンをビューにマッピングします。

URLconf・・・ああ、何か前に出て来てたな・・ 確か、urls.py だった。別名ディスパッチャー。

mysite/mysite/urls.py

"""mysite URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:
    https://docs.djangoproject.com/en/3.2/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path('polls/', include('polls.urls')),
    path('admin/', admin.site.urls),
]

ビューにマッピングします・・・

urlpatterns[]で定義されたとおりにパスを自動で割り当ててくれるという理解でいいんだよな?

独学って、こうゆう時に正解を確認しようが無いんだよな・・・

もっとビューを書いてみる

さて、ビューを追加しろ・・とあるが、

そもそもviews.pyは始めて開くが・・・

mysite/polls/views.py

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")

indexだけが定義されてるな・・・ここに追加すればいいのか?

mysite/polls/views.py

from django.shortcuts import render
from django.http import HttpResponse

def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")

def detail(request, question_id):
    return HttpResponse("You're looking at question %s." % question_id)

def results(request, question_id):
    response = "You're looking at the results of question %s."
    return HttpResponse(response % question_id)

def vote(request, question_id):
    return HttpResponse("You're voting on question %s." % question_id)

まだ、イメージがつかめないが・・・これだけで表示画面になるのか?

次のpath()コールを追加して、新しいviewを polls.urls モジュールと結びつけます。

ここは、pollsフォルダ内のurls.pyに追加するということか・・・

mysiteフォルダ内にもurls.pyがあってややこしいのだが、何で二つに分けているのか分からない・・・

今は言われたとおり追加する。

mysite/polls/urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('', views.index, name='index'),
    path('/', views.detail, name='detail'),
    path('/results/', views.results, name='results'),
    path('/vote/', views.vote, name='vote'),
]

お使いのブラウザで、”/polls/34/” を見てください。 detail() メソッドが実行され、URLで提供したIDが表示されます。

ん? ブラウザ表示するということはサーバー起動するんだよね?

C:\django_project\mysite>python manage.py runserver
Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).
August 25, 2021 - 21:10:53
Django version 3.2.6, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

“/polls/34/” を見てください・・・どういうこと?

ブラウザのアドレスバーに ” /polls/34/ ” と入れてみても「このサイトにアクセスできません」とエラー画面になるだけなんだが・・・

正確なアドレスは以下だ。

http://127.0.0.1:8000/polls/34/

” 127.0.0.1 ” とは、ローカルループバックアドレスと呼ばれ、自分自身を指す特別なアドレス。その後に続く8000とは、ポート8000番という意味だが、調べた限りでは別に8000番でなければならない、というわけではないらしい。適当に使っているようだ。

” /polls/34/ ” って略すことろ、サーバー知識前提で説明してるんだろうな。ビギナーはこういった小さな石で躓きやすい。

正しいアドレスでアクセスすると「You’re looking at question 34.」の文字が表示された!

次に、http://127.0.0.1:8000/polls/34/resultsと入力すると、
「You’re looking at the results of question 34.」

http://127.0.0.1:8000/polls/34/voteを入力すると、
「You’re voting on question 34.」

とりあえず、正しく表示されたようだ。

この記事をシェア

Comments are closed, but trackbacks and pingbacks are open.