django 008|テンプレート継承


テンプレートの継承

  • すべてのテンプレートに共通の適用を望む設計がある場合、同じテンプレートをコピーするのはあまりにも非効率です=>テンプレート継承は、すべての人が共通の属性
  • を維持することができます.
  • base.html
  • を作成する
    ここに共通の適用形式をもたらす
    (例は以下の通り)
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>BLOG</title>
        <link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
        <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM" crossorigin="anonymous"></script>
    </head>
    <body style="text-align: center;">
    
        <!---->
        <nav class="navbar navbar-expand-lg navbar-light bg-light">
            <div class="container-fluid">
              <a class="navbar-brand" href="#">Navbar</a>
              <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
                <span class="navbar-toggler-icon"></span>
              </button>
              <div class="collapse navbar-collapse" id="navbarSupportedContent">
                <ul class="navbar-nav me-auto mb-2 mb-lg-0">
                  <li class="nav-item">
                    <a class="nav-link active" aria-current="page" href="#">Home</a>
                  </li>
                  <li class="nav-item">
                    <a class="nav-link" href="#">Link</a>
                  </li>
                  <li class="nav-item dropdown">
                    <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
                      Dropdown
                    </a>
                    <ul class="dropdown-menu" aria-labelledby="navbarDropdown">
                      <li><a class="dropdown-item" href="#">Action</a></li>
                      <li><a class="dropdown-item" href="#">Another action</a></li>
                      <li><hr class="dropdown-divider"></li>
                      <li><a class="dropdown-item" href="#">Something else here</a></li>
                    </ul>
                  </li>
                  <li class="nav-item">
                    <a class="nav-link disabled" href="#" tabindex="-1" aria-disabled="true">Disabled</a>
                  </li>
                </ul>
                <form class="d-flex">
                  <input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
                  <button class="btn btn-outline-success" type="submit">Search</button>
                </form>
              </div>
            </div>
          </nav>
        <!--여기 윗 부분은 모든 곳에 적용될 예정인 nav var -->
      </body>
    </html>
    コンテナのプロパティ
  • を指定します.変更内容は固定する場所にあります.
    <!--위의 네브 태그 바로 아래에-->
     <div class="container">
              {% block content %}
              {% endblock %}
          </div>
  • は現在基地です.htmlの影響を受けた友人のhtmlを入力すると
  • になります.
    (1)属性を適用するhtmlページの上部
    {% extends 'base.html' %}
    {% block content %}
    変更内容
    {% endblock %}
    「{}」という形で私を追加すると、base.htmlの内容がコピーされていなくても、うまく応用できます.
  • settings.pyのDIRSセクションにテンプレートパス名(アプリケーション名/テンプレート)
  • を書き込みます.

  • 残りのhtmlもすべて適用すれば(第3のプロセス)、どこに行っても基礎になります.フォーマットが正しい
  • (+) urls.py管理方法


  • アプリケーションのurls.pyという名前のファイルを作成
    =>blogアプリケーションを作成し、blogアプリケーションにファイルを作成すればよい

  • crud後のurlsを作成します.py
  • from django.contrib import admin
    from django.urls import path
    from blog import views
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('', views.home, name="home"),
        path('<str:id>', views.detail, name="detail" ),
        path('new/',views.new, name="new"),
        path('create/', views.create, name="create"),
        path('edit/<str:id>', views.edit, name="edit"),
        path('update/<str:id>', views.update, name="update"),
        path('delete/<str:id>', views.delete, name="delete"),
    ]
  • ブログアプリのURL.pyに貼り付けますが、一番上のadminとデフォルトのhome&blog import viewsを削除します.viewsをimport*
  • に変換
    from django.contrib import admin
    from django.urls import path
    from .views import *
    urlpatterns = [
        path('<str:id>',detail, name="detail" ),
        path('new/',new, name="new"),
        path('create/', create, name="create"),
        path('edit/<str:id>', edit, name="edit"),
        path('update/<str:id>', update, name="update"),
        path('delete/<str:id>', delete, name="delete"),
    ]
  • 元URL.py admin、home、import domeに変更&url
  • をブログアプリケーションにロード
    from django.contrib import admin
    from django.urls import path, include
    from blog.views import home
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('',home, name="home"),
        path('blog/', include('blog.urls'))
    ]
    =>各アプリケーションのurl管理が容易で、パスも清潔です
    (パスを表示するシーン)

  • 細部に行くとき.


  • newに行った時


  • editに移動する場合