Bagaimana mengesampingkan cetakan¶
Dalam proyek anda, anda mungkin ingin menimpa sebuah cetakan dalam aplikasi Django lain, apakai itu berupa aplikasi pihak-ketiga atau aplikasi bantuan seperti django.contrib.admin
. Anda dapat antara menaruh cetakan menimpa dalam direktori cetakan proyek anda atau dalam sebuah direktori cetakan aplikasi.
Jika anda mempunyai aplikasi dan direktori cetakan proyek yang kedua kandungan menimpa, pemuat cetakan Django awalan akan mencoba memuat cetakan dari direktori tingkat-proyek dahulu. Dengan kata lain, DIRS 1
dicari sebelum APP_DIRS 2
.
Lihat juga
Baca Menimpa cetakan widget siap-pakai jika anda sedang mencari untuk melakukannya.
Menimpa dari direktori cetakan proyek¶
Pertama, kami akan menjelajahi menimpa cetakan dengan membuat cetakan pengganti dalam direktori cetakan proyek anda.
Mari kita katakan anda sedang mencoba menimpa cetakan untuk aplikasi pihak-ketiga disebut blog
, yang menyediakan cetakan blog/post.html
dan blog/list.html
. Pengaturan terkait untuk proyek anda akan terlihat seperti:
from pathlib import Path
BASE_DIR = Path(__file__).resolve().parent.parent
INSTALLED_APPS = [
...,
"blog",
...,
]
TEMPLATES = [
{
"BACKEND": "django.template.backends.django.DjangoTemplates",
"DIRS": [BASE_DIR / "templates"],
"APP_DIRS": True,
# ...
},
]
Pengaturan TEMPLATES
dan BASE_DIR
akan sudah ada jika anda membuat proyek anda menggunakan cetakan proyek awalan. Pengaturan yang butuh dirubah adalah DIRS1
.
Pengaturan ini menganggap anda mempunyai sebuah direktori templates
dalam akar dari proyek anda. Untuk menimpa cetakan untuk aplikasi blog
, buat sebuah folder dalam direktori templates
, dan tambah berkas-berkas cetakan ke folder itu.
templates/
blog/
list.html
post.html
Pemuat cetakan pertama mencari untuk cetakan dalam direktori DIRS
. ketika tampilan dalam aplikasi blog
untuk cetakan blog/post.html
dan blog/list.html
, pemuat akan mengembalikan berkas-berkas anda telah buat.
Menimpa dari direktori cetakan aplikasi¶
Sejak anda sedang menimpa cetakan bertempat di luar dari satu dari aplikasi proyek anda, itu adalah lebih umum menggunakan metode pertama dan menaruh cetakan penimpaan dalam sebuah folder cetakan proyek. Jika anda memilih, bagaimanapun, itu juga memungkinkan menaruh penimpaan dalam sebuah direktori cetakan aplikasi.
Pertama, pastikan pengaturan cetakan anda memeriksa didalam direktori aplikasi:
TEMPLATES = [
{
# ...
"APP_DIRS": True,
# ...
},
]
Jika anda ingin menaruh cetakan penimpaan dalam sebuah aplikasi disebut myapp
dan cetakan untuk menima bernama blog/list.html
dan blog/post.html
, kemudian struktur direktori anda akan terlihat seperti:
myapp/
templates/
blog/
list.html
post.html
Dengan APP_DIRS1
disetel menjadi True
, pemuat cetakan akan terlihat dalam direktori cetakan aplikasi dan menemukan cetakan.
Memperluas cetakan yang diganti¶
With your template loaders configured, you can extend a template using the
{% extends %}
template tag whilst at the same time overriding
it. This can allow you to make small customizations without needing to
reimplement the entire template.
Sebagai contoh, anda dapat menggunakan teknik ini untuk menambahkan logo penyesuaian pada cetakan admin/base_site.html
:
{% extends "admin/base_site.html" %}
{% block branding %}
<img src="link/to/logo.png" alt="logo">
{{ block.super }}
{% endblock %}
Titik kunci pada catatan:
Contoh membuat sebuah berkas pada
templates/admin/base_site.html
yang menggunakan tingkat-proyek dikonfigurasikan direktoritemplates
directory untuk menimpaadmin/base_site.html
.Cetakan baru meluas
admin/base_site.html
, yang merupakan cetakan sama seperti sedang ditimpa.Cetakan hanya mengganti blok
branding
, menambahkan logo penyesuaian, dan menggunakanblock.super
untuk mempertahankan konten sebelumnya.Sisa dari cetakan diturunkan tidak berubah dari
admin/base_site.html
.
This technique works because the template loader does not consider the already
loaded override template (at templates/admin/base_site.html
) when
resolving the extends
tag. Combined with block.super
it is a powerful
technique to make small customizations.