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 페이지에는 표시되지 않습니다. 문서화하거나 코드 줄에 주석을 달 때 유용 할 수 있습니다.