템플릿 엔진을 생성하면 개발자가 웹 렌더링 시스템의 기초를 이해하는 데 도움이 됩니다. RelaxTemplates는 템플릿 렌더링 프로세스를 단순화하는 Python 기반의 경량 템플릿 엔진입니다. 교육적이고 초보자 친화적으로 설계된 RelaxTemplates는 변수 대체, 루프, 조건부, 상속 및 재사용 가능한 스니펫과 같은 핵심 개념을 보여 주므로 템플릿 엔진 아키텍처에 대해 자세히 알아보고 싶은 개발자에게 이상적인 선택입니다.
RelaxTemplates는 개발자가 템플릿 기능을 탐색하고 이를 기반으로 구축할 수 있도록 템플릿 엔진을 명확하게 설명하려는 요구에서 탄생했습니다. Django 또는 Jinja2와 같은 프로덕션 준비 엔진과 달리 RelaxTemplates는 단순성을 강조하여 사용자가 사용자 정의 추가 또는 기능 확장을 실험할 수 있는 더 많은 제어권을 제공합니다.
RelaxTemplates는 최신 템플릿 엔진에서 기대되는 필수 기능을 제공합니다.
각 기능과 사용 방법을 살펴보겠습니다!
RelaxTemplates 사용을 시작하려면 PyPI에서 간단히 설치하세요.
pip install relaxtemplates
그런 다음 패키지를 가져오고 템플릿 파일을 정의합니다. RelaxTemplates 템플릿은 변수, 블록 및 기타 템플릿 논리를 통합하기 위한 특수 구문이 포함된 표준 HTML 파일입니다.
RelaxTemplates는 중괄호와 태그를 사용하여 변수, 조건부, 루프 및 기타 템플릿 요소를 정의하는 간단한 구문을 사용합니다.
변수는 제공된 컨텍스트의 값으로 동적으로 대체되도록 {{ }}로 래핑됩니다. 예를 들어 다음 템플릿의 user_name 변수는 사용자 이름으로 대체됩니다.
<div>Hello, {{ user_name }}!</div>
{'user_name': 'Alice'}와 같은 컨텍스트로 렌더링하면 다음이 출력됩니다.
pip install relaxtemplates
RelaxTemplates의 조건문을 사용하면 특정 조건에 따라 콘텐츠를 렌더링할 수 있습니다. 지원되는 연산자에는 >, <, >=, <=, == 및 !=가 있습니다. 예는 다음과 같습니다.
<div>Hello, {{ user_name }}!</div>
user_age가 18세 이상인 경우 템플릿은 첫 번째 메시지를 출력합니다. 그렇지 않으면 대체 메시지가 표시됩니다.
{% Each %} 블록은 컬렉션을 반복하여 항목을 나열하거나 반복 섹션을 표시하는 쉬운 방법을 제공합니다.
<div>Hello, Alice!</div>
유연성을 더하려면 루프 내에서 ..를 사용하여 외부 범위의 값을 참조하세요. 이는 현재 항목 외부의 컨텍스트 데이터가 필요할 때 특히 유용합니다.
{% if user_age > 18 %} <p>Welcome, adult user!</p> {% else %} <p>Welcome, young user!</p> {% end %}
RelaxTemplates를 사용하면 템플릿에서 직접 함수를 호출할 수 있습니다. 함수는 위치 인수와 키워드 인수를 모두 받아들일 수 있습니다.
{% each items %} <p>{{ it }}</p> {% end %}
이 예에서는 format_date 및 log가 템플릿 내에서 호출되어 필요에 따라 날짜 형식 지정 또는 로깅을 활성화합니다.
RelaxTemplates의 가장 강력한 기능 중 하나는 템플릿 상속 지원입니다. 이를 통해 기본 템플릿(예: 표준 레이아웃)을 정의하고 이를 하위 템플릿으로 확장할 수 있습니다.
기본 템플릿(base.html):
{% each items %} <p>Outer name: {{ ..name }}</p> <p>Item: {{ it }}</p> {% end %}
하위 템플릿(child.html):
<p>{% call format_date date_created %}</p> <p>{% call log 'Event logged' level='debug' %}</p>
이 설정을 사용하면 전체 레이아웃을 다시 정의하지 않고도 하위 템플릿이 제목, 콘텐츠 등의 특정 블록을 재정의할 수 있습니다.
템플릿 내에 머리글이나 바닥글과 같은 재사용 가능한 템플릿 스니펫을 삽입하려면 {% include 'template_name' %}을 사용하세요.
<!DOCTYPE html> <html> <head> <title>{% block title %}Default Title{% endblock %}</title> </head> <body> <div id="content"> {% block content %}Default content.{% endblock %} </div> </body> </html>
이 기능은 공통 섹션을 개별 파일로 분리하여 템플릿을 모듈화하고 중복을 줄이고 가독성을 높이는 데 도움이 됩니다.
템플릿 및 컨텍스트 정의:
{% extend 'base' %} {% block title %}Custom Page Title{% endblock %} {% block content %} <p>This is custom content for the child template.</p> {% endblock %}
템플릿 렌더링:
{% include 'header' %} <p>Welcome to the page!</p> {% include 'footer' %}
RelaxTemplate은 Django 또는 Jinja2와 같은 강력한 엔진의 최적화와 일치하지 않을 수 있지만 소규모 애플리케이션 및 실험에서는 효율적으로 작동합니다. 다음은 RelaxTemplate과 다른 엔진의 비교입니다:
Template | Runs | Time Taken (ms) |
---|---|---|
Relaxtemplates | 10,000 | 0.19 |
Django | 10,000 | 0.39 |
Django (default loader) | 10,000 | 0.22 |
Jinja2 | 10,000 | 3.28 |
Jinja2 (env) | 10,000 | 0.10 |
이러한 결과는 RelaxTemplate이 프로덕션용은 아니지만 테스트, 학습 및 소규모 애플리케이션을 위한 효율적인 옵션임을 보여줍니다.
RelaxTemplate은 기여에 열려 있으며 새로운 아이디어는 언제나 환영합니다! 기능 추가, 코드 최적화, 문서 개선에 관심이 있다면 이 프로젝트를 자유롭게 탐색하고 실험해 보세요.
RelaxTemplates로 즐거운 템플릿 만들기!
위 내용은 RelaxTemplates 프로젝트 구축: 초보자에게 친숙한 Python 템플릿 엔진의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!