django 008 | template 상속

35304 단어 djangodjango

template 상속

  • 모든 templates에 공통적으로 적용되게 하고 싶은 디자인이 있을 때 똑같이 복붙해나가는 것은 너무 비효율적 => template 상속으로 모두가 공통적인 속성 유지하도록 해주기
  1. 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>
  1. 고정이 될 자리 안에 내용이 바뀌는 부분이 해당하는 곳에 container 속성 지정
<!--위의 네브 태그 바로 아래에-->
 <div class="container">
          {% block content %}
          {% endblock %}
      </div>
  1. 이제 base.html의 영향을 받을 친구들의 html에 입력해주면 됨

(1) 속성 적용될 html 페이지 맨 위에
{% extends 'base.html' %}

{% block content %}

바뀌는 내용

{% endblock %}

형태로 저 "{}" 추가해주면 base.html의 내용이 복붙 아니어도 잘 적용됨

  1. settings.py의 'DIRS'" 부분에 templates 경로명 적어주기 ('앱이름/templates')

  1. 나머지 html도 모두 적용을 해주면 (3번의 과정) 어딜 가도 base.html의 형식이 잘적용됨

(+) urls.py 관리 방법

  1. 앱에 urls.py 라는 파일을 하나 생성
    => 우리는 blog 앱 제작했으므로 blog앱에다가 파일 생성하면 됨

  2. 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"),
]
  1. blog 앱의 urls.py에다가 얘를 그대로 복붙해주되, 맨 위 admin이랑 기본이 되는 home 삭제 & from blog import views 를 from .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"),
]
  1. 원래 urls.py에는 admin, home 남기고 import도 홈으로 수정 & 블로그 앱 내의 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 관리하기 easier, 경로도 깔끔하게 나온다
(경로 나오는 장면)

  • detail로 갔을 때

  • new로 갔을 때

  • edit으로 갔을 때

좋은 웹페이지 즐겨찾기