Django-템플릿 시스템
Django를 사용하면 python과 HTML을 분리 할 수 있으며, python은 뷰로, HTML은 템플릿으로 이동합니다. 둘을 연결하기 위해 Django는 렌더링 함수와 Django 템플릿 언어에 의존합니다.
렌더 기능
이 함수는 세 가지 매개 변수를 취합니다.
Request − 초기 요청.
The path to the template − 이것은 프로젝트 settings.py 변수의 TEMPLATE_DIRS 옵션에 상대적인 경로입니다.
Dictionary of parameters− 템플릿에 필요한 모든 변수를 포함하는 사전. 이 변수를 만들거나 locals ()를 사용하여 뷰에 선언 된 모든 지역 변수를 전달할 수 있습니다.
Django 템플릿 언어 (DTL)
Django의 템플릿 엔진은 응용 프로그램의 사용자 대면 계층을 정의하는 미니 언어를 제공합니다.
변수 표시
변수는 다음과 같습니다. {{variable}}. 템플릿은 렌더링 함수의 세 번째 매개 변수에서 뷰가 보낸 변수로 변수를 대체합니다. 오늘 날짜를 표시하도록 hello.html을 변경해 보겠습니다.
hello.html
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
</body>
</html>
그러면 우리의 견해는-
def hello(request):
today = datetime.datetime.now().date()
return render(request, "hello.html", {"today" : today})
이제 URL / myapp / hello에 액세스 한 후 다음 출력을 얻습니다.
Hello World!!!
Today is Sept. 11, 2015
이미 알고 있듯이 변수가 문자열이 아닌 경우 Django는 __str__ 메서드를 사용하여 표시합니다. 그리고 같은 원리로 파이썬에서하는 것처럼 객체 속성에 접근 할 수 있습니다. 예 : 날짜 연도를 표시하려면 내 변수는 {{today.year}}입니다.
필터
표시 시간에 변수를 수정할 수 있도록 도와줍니다. 필터 구조는 다음과 같습니다. {{var | filters}}.
Some examples −
{{string|truncatewords:80}} −이 필터는 문자열을 자르므로 처음 80 개 단어 만 표시됩니다.
{{string|lower}} − 문자열을 소문자로 변환합니다.
{{string|escape|linebreaks}} − 문자열 내용을 이스케이프 한 다음 줄 바꿈을 태그로 변환합니다.
변수의 기본값을 설정할 수도 있습니다.
태그
태그를 사용하면 if 조건, for 루프, 템플릿 상속 등의 작업을 수행 할 수 있습니다.
다음 경우 태그
Python에서와 마찬가지로 템플릿에서 if, else 및 elif를 사용할 수 있습니다.
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
</body>
</html>
이 새 템플릿에서는 날짜에 따라 템플릿이 특정 값을 렌더링합니다.
태그
'if'와 마찬가지로 Python과 똑같이 작동하는 'for'태그가 있습니다. 템플릿에 목록을 전송하도록 hello보기를 변경해 보겠습니다.
def hello(request):
today = datetime.datetime.now().date()
daysOfWeek = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
return render(request, "hello.html", {"today" : today, "days_of_week" : daysOfWeek})
{{for}}를 사용하여 해당 목록을 표시하는 템플릿 −
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
</body>
</html>
그리고 우리는 다음과 같은 것을 얻어야합니다.
Hello World!!!
Today is Sept. 11, 2015
We are I don't know.
Mon
Tue
Wed
Thu
Fri
Sat
Sun
태그 차단 및 확장
템플릿 상속 없이는 템플릿 시스템을 완성 할 수 없습니다. 즉, 템플릿을 디자인 할 때 페이지에 선택한 탭에 대한 특수 CSS가 필요할 수있는 것처럼 자녀의 템플릿이 자신의 필요에 따라 채울 구멍이있는 기본 템플릿이 있어야합니다.
hello.html 템플릿을 main_template.html에서 상속하도록 변경해 보겠습니다.
main_template.html
<html>
<head>
<title>
{% block title %}Page Title{% endblock %}
</title>
</head>
<body>
{% block content %}
Body content
{% endblock %}
</body>
</html>
hello.html
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
위의 예에서 / myapp / hello를 호출하면 이전과 동일한 결과를 얻을 수 있지만 이제 코드를 리팩토링하기 위해 extends 및 block에 의존합니다.
main_template.html에서 태그 블록을 사용하여 블록을 정의합니다. 제목 블록에는 페이지 제목이 포함되고 콘텐츠 블록에는 페이지 기본 콘텐츠가 포함됩니다. home.html에서 extends를 사용하여 main_template.html에서 상속 한 다음 위에서 정의한 블록 (내용 및 제목)을 채 웁니다.
댓글 태그
주석 태그는 HTML 주석이 아닌 템플릿에 주석을 정의하는 데 도움이되며 HTML 페이지에는 표시되지 않습니다. 문서화하거나 코드 줄에 주석을 달 때 유용 할 수 있습니다.