django 008|テンプレート継承
テンプレートの継承
ここに共通の適用形式をもたらす
(例は以下の通り)
<!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>
(1)属性を適用するhtmlページの上部
{% extends 'base.html' %}
{% block content %}
変更内容
{% endblock %}
「{}」という形で私を追加すると、base.htmlの内容がコピーされていなくても、うまく応用できます.
(+) 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"),
]
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"),
]
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に移動する場合
Reference
この問題について(django 008|テンプレート継承), 我々は、より多くの情報をここで見つけました https://velog.io/@myway00/django-008-template-상속テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol