2
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Djangoを使ったWEBアプリケーションの開発【テンプレート追加編】

Last updated at Posted at 2020-09-30

リクエスト処理編の続き

テンプレート

現状、/posts/へアクセスするとurls.pyが呼び出され、views.pyから「Hello, World!」を直接返して表示する処理を記載しています。ここでテンプレートを作成し、それを表示させるようにします。

テンプレートを追加

これからテンプレートを作成しviews.pyを書き換え、ルーティング→ビュー→テンプレートという処理に変更していきます。

まずは、アプリケーションフォルダ(今回は「posts」フォルダ)に「templates」フォルダを作成し、さらにその中にアプリケーションフォルダと同じ名前のフォルダを作成します。
※Djangoのルールとしてtemplatesフォルダ内にアプリケーションフォルダと同じ名前のフォルダが必要。

次にtemplates内のpostsフォルダにHTMLファイルを作成します。

index.html
<!DOCTYPE html>
<html lang="ja-jp" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
  </head>
  <body>
    <h2>テストページです。</h2>
  </body>
</html>

さらに、作成したHTMLファイルを表示するためviews.pyを修正します。

views.py
def index(request):
    #return HttpResponse("Hello, World!") ←ここをコメントアウト
    return render(request, 'posts/index.html') #新しく追加した行

こうすることで、views.pyが呼び出されたとき直接「Hello, World!」を返さず、templates内にあるpostsフォルダのindex.htmlを参照して返すことができます。
Djangoサーバーを立ち上げて「http://127.0.0.1:8000/posts/」で表示すると下記のようになります。
テンプレート.png

2
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?