Оформление html: HTML — правила оформления кода

Содержание

HTML — правила оформления кода

HTML — правила оформления кода

1. Синтаксис

1.1 Два пробела в качестве отступа

Отступы позволяют визуально оценить структуру документа и быстро переключаться между его фрагментами. Размер отступа настраивается в редакторе. Также во многих редакторах можно включить отображение пробельных символов и преобразовать отступы.

Хорошо
<!DOCTYPE html>
<html lang="ru">
  <head>
    <meta charset="UTF-8">
    <title>Ваша страница</title>
  </head>
  <body>
    <h2>Страница</h2>
    <p>Текст</p>
  </body>
</html>
Плохо
<!DOCTYPE html>
<html lang='ru'>
<head>
	<meta charset='UTF-8'>
    <title>Ваша страница</title>
</head>
<body>
<h2>Страница</h2>
<p>Текст</p>
</body>
</html>

1.2 Теги и атрибуты записываются в нижнем регистре

Символы нижнего регистра не привлекают к себе большого внимания, и вам легче будет найти нужный.

Хорошо
<div>
  <img src="./i/userpic.png" title="Иванов Иван">
  <a href="/profile/">Перейти в профиль</a>
</div>
Плохо
<DIV>
  <Img Src="./i/userpic.png" titLE="Иванов Иван">
  <A href="/profile/">Перейти в профиль</a>
</DIV>

1.3 Отдельные логические блоки отбиваются пустой строкой

Это облегчает работу с кодом и визуально создает структуру документа.

Хорошо
<h2>Заголовок первого уровня</h2>
<p>Первый параграф</p>
<h3>Заголовок второго уровня</h3>
<ul>
  <li>Первый пункт</li>
  <li>Второй пункт</li>
  <li>Третий пункт</li>
</ul>
<h4>Заголовок третьего уровня</h4>
<figure>
  <figcaption>Блок с картинкой</figcaption>
  <img src="../img/image.jpg">
</figure>
Плохо
<h2>Заголовок первого уровня</h2>
<p>Первый параграф</p>
<h3>Заголовок второго уровня</h3>
<ul>
  <li>Первый пункт</li>
  <li>Второй пункт</li>
  <li>Третий пункт</li>
</ul>
<h4>Заголовок третьего уровня</h4>
<figure>
  <figcaption>Блок с картинкой</figcaption>
  <img src=".
./img/image.jpg"> </figure>

1.4 Используйте только двойные кавычки

При написании значений атрибутов используйте только двойные кавычки.

Хорошо
<div>
  <img src="first-img.jpg" alt="Первая картинка">
</div>
Плохо
<div>
  <img src='first-img.jpg' alt='Первая картинка'>
</div>

1.5 Не ставим пробелов перед и после символа =

Поскольку правая часть непосредственно относится к левой, то атрибут и его значение должны быть написаны без пробелов.

Хорошо
<p>Это хороший пример</p>
Плохо
<p id ="first" class= "post">Это плохой пример</p>

1.6 Между атрибутами один пробел

Не используем переносов строк между атрибутами, только один пробел. Перенос строк принят в css-документах, но не в html-разметке. Пишите все атрибуты элемента в строку.

Хорошо
<figure>
  <img src="logo. jpg" alt="Логотип">
  <figcaption>Логотип компании</figcaption>
</figure>
Плохо
<figure>
  <img
  src="logo.jpg"
  alt="Логотип">
  <figcaption>Логотип компании</figcaption>
</figure>

2. Валидность

Html-документ должен проходить проверку на валидность. Для проверки используйте валидатор.

3. !DOCTYPE

Первой строчкой в HTML-документе должен идти актуальный doctype. Это необходимо чтобы браузер верно отображал страницу. Это обеспечит единообразное отображение во всех современных браузерах.

<!DOCTYPE html>
<html lang="ru">
  <head>…</head>
  <body>…</body>
</html>

4. Кодировка

Кодировка символов в html-документе всегда должна быть указана явно. Это обеспечит верное отображение текста. Кодировка utf-8 подходит всегда, за редким исключением.

<head>
  <meta charset="utf-8">
  <title>Заголовок</title>
</head>

5.

Подключение стилей

Файлы со стилями подключаются внутри тега <head> при помощи <link>. Атрибут type для тега <link> указывать не нужно, так как значение text/css устанавливается по умолчанию.

Хорошо: стилевой файл подключён в секции head
<!DOCTYPE html>
<html lang="ru">
  <head>
    <link rel="stylesheet" href="style.css">
  </head>
  <body>…</body>
</html>
Плохо: стилевой файл подключён в секции body
<!DOCTYPE html> <html lang="ru"> <head>…</head> <body> <link rel="stylesheet" href="style.css"> </body> </html>

6. Подключение скриптов

Скрипты при загрузке блокируют отображение содержимого страницы. По этой причине следует подключать их в самом конце html-документа.

При подключении скриптов в теге <script> атрибут type указывать не нужно, так как значение text/javascript устанавливается по умолчанию.

Хорошо: скрипт подключается перед </body>
<!DOCTYPE html>
<html lang="ru">
  <head>…</head>
  <body>
    <!-- Содержимое страницы -->
    <script src="app.js"></script>
  </body>
</html>
Плохо: скрипт подключается в секции <head>
<!DOCTYPE html>
<html lang="ru">
  <head>
    <script src="app.js"></script>
  </head>
  <body>…</body>
</html>

7. Атрибуты и их порядок

У HTML-элементов атрибут class пишется первым. Единообразное написание помогает легче считывать код и по классам быстрее разбираться в назначении блоков.

Остальные атрибуты могут быть расставлены в любом порядке, но тоже единообразно для схожих элементов.

<a href="/" data-name="element">Ссылка</a>
<input type="text" name="test">
<img src="img.jpg" alt="Картинка">

8.

Логические атрибуты

Для логических атрибутов (например, checked, disabled, required) значение не указывается, а сами атрибуты указываются последними и в единообразной последовательности во всём документе.

<!-- checked="checked" необязательно -->
<input type="checkbox" required checked>
<input type="text" disabled>
<select>
  <option value="1" selected>1</option>
</select>

9. Подписи

input

Для улучшения опыта пользователя, при нажатии на подпись поля, само поле должно активироваться. Для этого поле формы связывается с описанием при помощи идентификатора и атрибута for тега <label>.

Хорошо: элемент формы radio связан с подписью через id и for
<input type="radio">
<label for="choose">Радио кнопка</label>
Хорошо: элемент формы radio и подпись обёрнуты в label
<label>
  <input type="radio"> Радио кнопка
</label>
Плохо: подпись не связана с элементом формы
<input type="radio"> Радио кнопка

10.

Атрибут языка

Для элемента <html> в атрибуте lang должен указываться верный язык документа. Это помогает системам перевода определить, какие использовать языковые правила.

<!DOCTYPE html>
<html lang="ru">
  <head>…</head>
  <body>…</body>
</html>

Руководство по оформлению кода HTML/CSS

Хочешь знать больше про веб?

Подпишись на наш телеграм-канал TechRocks WEB-разработка?

Подписаться

×

Код HTML/CSS нужно оформлять красиво, а значит особенности верстки – обязательная часть программы обучения веб-разработке. Сайт proglib.io рассказал, как освоить нужные знания с нуля.

Photo by Jantine Doornbos on Unsplash

С хорошо оформленной и структурированной разметкой намного удобнее работать как самому верстальщику, так и его коллегам. Нужные участки кода будут находиться гораздо быстрее, а внести в них изменения и дополнения станет проще. До сих пор не утихают споры о том, как же правильно писать код. Перечислим основные правила, которые следует соблюдать при создании разметки HTML.

Делайте отступы

Выделяйте новую строку для каждого блочного, табличного или списочного элемента. Вложенные элементы отделяйте четырьмя (или двумя) пробелами от элемента-родителя.

Тег div является вложенным элементом относительно section.

<section>
    <div>
    </div>
</section>

В свою очередь теги h2 и p выравниваются относительно тега div, не создавая «лесенки».

<section>
    <div>
        <h2>Заголовок</h2>
        <p>Текст</p>
    </div>
</section>

Это правило не распространяется на строчные теги (iuabspan) внутри абзаца. Например, тег span не нужно начинать с новой строки и делать от него отступы.

Выравнивайте теги по одной вертикальной линии

Теги не должны хаотично плясать туда-сюда на странице редактора. Чтобы с легкостью ориентироваться в документе, пишите открывающий и закрывающий теги на одной вертикальной линии друг под другом.

Так писать не надо:

<section> <div> <h2>Заголовок</h2> <p>Текст</p> </div> </section>

Комментируйте код

Когда в разметке идет подряд много закрывающих тегов, ставьте комментарий (название класса) рядом с ним. Тогда вам не придется гадать, какой именно класс закрывается.

<div>
    <div>
        <div>
          . ....
        </div><!-- .title -->
    </div><!-- .header -->
</div><!-- .wraper -->

Начало каждого блока желательно начинать с короткого комментария с названием секции. Это очень удобно и позволит вам легко ориентироваться в структуре документа.

<!-- Footer -->
<footer>
    <div></div>
</footer>

Всегда пишите в нижнем регистре

Весь код должен быть написан в нижнем регистре. Это относится к названиям элементов и атрибутов, значениям атрибутов, селекторам, свойствам и их значениям (кроме текста). Текст внутри тегов можно писать с заглавной буквы в начале предложений, а для остального существует свойство text-transform: uppercase;.

Используйте кодировку UTF-8

UTF-8 – один из самых распространенных стандартов кодирования, который позволяет наиболее компактно хранить и передавать символы Юникода.  Убедитесь, что ваш редактор использует UTF-8. Всегда указывайте кодировку в шаблонах и документах HTML с помощью <meta charset="utf-8">. Опускайте кодировку для файлов CSS, поскольку для них UTF-8 задана по умолчанию.

Используйте валидный HTML

Валидная разметка – это код, который написан в соответствии с определенными стандартами. Их разработал Консорциум Всемирной Паутины – World Wide Web Consortium (W3C). При помощи таких инструментов, как W3С HTML Validator, можно проверить качество кода HTML и CSS. Написание валидного HTML оттачивает знание ограничений языка разметки и понимание технических требований.

Используйте семантическую разметку

Семантическая верстка (разметка) – это подход к созданию веб-страниц, основанный на расстановке тегов HTML в соответствии с их семантикой. Проще говоря, используйте теги по назначению: <hX> для заголовков, <p> для абзацев, <a> для ссылок и т. д. Это поможет поисковому роботу проанализировать страницу сайта и подготовить ее описание для пользователей, а также повысит приоритет выдачи.

Для людей с ограниченными возможностями создается специальный софт, который ориентирован на семантическую разметку. Постарайтесь указать альтернативное содержимое для картинок, видео или анимаций, заданных с помощью canvas. Это поможет людям со слабым зрением понять, о чем говорится в аудио- или видеозаписи.

Не указывайте протокол при добавлении внешних ресурсов

Опускайте название протокола (http:// или https://) в ссылках на картинки и другие внешние ресурсы, файлы стилей или скрипты. Это делает ссылку относительной и предотвращает, например, использование незащищенного контента на защищенном сайте, а также незначительно уменьшает размер файлов.

Не используйте необязательные теги и лишние обертки

Для уменьшения размера файлов и лучшей читаемости старайтесь избегать использования необязательных тегов и лишних оберток (wrapper). В спецификации HTML5 есть их список.

Изучите правила оформления CSS

Выбирайте осмысленные имена классов и идентификаторы – так куда проще понять, за что они отвечают, и придется меньше менять код в будущем. Некоторые разработчики пользуются для не требующих специального обозначения классов шаблонными именами, которые уменьшают необходимость ненужных изменений в документе.

Изучите нюансы синтаксиса CSS

Ставьте точку с запятой после каждого объявления. Это необходимо для беспрепятственного добавления новых свойств и уменьшения путаницы. Используйте пробелы после двоеточий в объявлениях. Это поможет вам лучше ориентироваться в документе CSS. Начинайте каждый селектор или объявление с новой строки. По возможности объединяйте свойства отдельных блоков в группы и обозначайте их комментариями, разделяя переносом строки. Не указывайте единицы измерения для нулевых значений, если на это нет причины. Трехсимвольная шестнадцатиричная запись для цветов короче и занимает меньше места (color: #ааа;).

Используйте препроцессоры

Препроцессор CSS добавляет ранее недоступные возможности с помощью новых синтаксических конструкций. Основная его задача – упростить и ускорить разработку, а также поддержку стилей в проектах. Препроцессоры преобразуют написанный с использованием специального языка код в чистый и валидный CSS. С их помощью улучшается читабельность и структурированность кода, а также увеличивается производительность труда верстальщика.

Используйте автопрефиксер

Префиксы нужны, чтобы «подружить» свойства CSS c различными браузерами. Изначально они были придуманы, чтобы помочь разработчикам браузеров адаптировать спецификацию под свои нужды. Чтобы не заниматься этим самостоятельно, используйте утилиту нового поколения autoprefixer для добавления префиксов к экспериментальным свойствам из CSS-3.

Будьте последовательны!

Следует придерживаться определенного стиля написания кода. Чистый и красивый код говорит об уровне профессионализма верстальщика и его отношении к работе.

Создание шаблонов макета HTML

Вы реализуете один файл шаблона HTML для каждого из типов заголовков, которые поддерживает ваша тема (заголовок, без заголовка и заставка).

Каждый файл шаблона должен содержать базовый код и обязательные теги темы, используемые для вставки контента. Мы также предоставляем дополнительные теги для извлечения другого предварительно определенного контента, и вы можете создавать настраиваемые теги для создания дополнительных областей, в которые пользователи могут добавлять контент. Помимо добавления тегов, вы также можете дополнительно создать область заголовка и разделы, которые позволят вашим пользователям изменять фон, макет, а для разделов — возможность копировать и перемещать их.

Вы можете использовать существующий HTML из другой темы или создать свой собственный с нуля. Убедитесь, что ваши таблицы стилей поддерживают все стили, которые вы используете в HTML.

Создать файл шаблона HTML ​

Вам необходимо создать по одному шаблону для каждого из следующих типов заголовков, которые вы хотите поддерживать:

  • Заголовок : Имеет область строки заголовка с навигацией и заголовком/логотипом над заголовком область, которая обычно состоит из изображения баннера или видео. Область содержимого отображается под изображением баннера.
Тип заголовка содержит баннер над содержимым
  • Нет заголовка : Нет области заголовка с изображением баннера. Отображаются только область строки заголовка и области содержимого.
Тип No Header не отображает баннер
  • Splash : не имеет области содержимого, а изображение баннера соответствует полному размеру страницы.
Тип Splash имеет изображение баннера и не имеет области содержимого

​Вы можете создать файл шаблона, изменив существующий шаблон, или создав новый.

Чтобы изменить существующий шаблон, просто откройте его в редакторе кода. Чтобы создать шаблон с нуля, в редакторе кода щелкните значок + рядом с HEADER TYPE и выберите New Header Type . В редакторе открывается файл с обязательными тегами темы. Вы должны добавить основной код и код для отображения обязательных тегов (ниже). Щелкните значок Настройки , чтобы задать имя файла или удалить его.

Вы также можете работать извне и загрузить свой шаблон. Нажмите 9Нажмите значок 0014 + и выберите Типы заголовков загрузки .

The Foundation ​

​Каждому типу страниц требуется базовый код Foundation, показанный ниже. Присвойте тегу body класс, отражающий тип этой страницы:

  • Заголовок : header-page
  • Нет заголовка : страница без заголовка
  • Страница-заставка : страница-заставка

Например, в примере ниже показана основа для шаблона заголовка.



<голова>
    
    

<тело>

 

​Если вы создаете свою тему, используя существующую тему в качестве основы, убедитесь, что вы не удалили какой-либо из основного кода.

Обязательные теги тем ​

​Все темы Weebly должны включать следующие теги:

  • {название} или {логотип) : Используйте {название} для отображения только названия сайта. Используйте {logo} , чтобы позволить владельцу сайта решить, использовать ли заголовок или файл логотипа, который они будут загружать.
  • {меню} : Отображает страницы сайта
  • {content} : Отображает основной контент на странице. Большая часть этого контента обрабатывается партиалами.
  • {нижний колонтитул} : Отображает содержимое нижнего колонтитула внизу страницы

Где вы размещаете эти теги и как вы стилизуете сгенерированный контент, зависит от вас. Если вы создаете новый файл (и не редактируете файл из существующей темы), они добавляются за вас.

Примечание: Редактор добавляет тег {title} , но вы можете заменить его тегом {logo} , если хотите.

  На этом рисунке показано, где эти теги используются в базовой теме:

Обязательные теги в базовой теме

Вот код из базовой темы, показывающий обязательные теги:

<тело>
<дел>
    <дел>
        <дел>
            . . .
            {логотип}
            
{меню
<дел> <тип ввода="флажок"> {меню}
. . . <дел>
{контент}
{нижний колонтитул
. . .

Необязательные теги

Если ваша тема поддерживает значки социальных сетей, поиск и номер телефона/текст с помощью параметров, вам необходимо добавить следующие теги:

Если вы хотите, чтобы ваша тема отображала заголовок и вспомогательный текст абзаца (например, на целевой странице), вы можете использовать следующие теги заголовков:

Примечание: Владельцы сайтов должны явным образом включить параметры (телефон, социальные сети, поиск) при использовании параметров. Поиск доступен только на платных сайтах

На этом рисунке показано, где эти теги используются в теме Impact.

Дополнительные теги для отображения контактов, социальных сетей и поисковых ссылок

Вот код, показывающий, как эти теги используются в теме Impact.

<дел>
    <дел>
        
{поиск
{социальный
{телефон:текст
<дел> <дел> <дел>

{headline:text global="false"}

{headline-paragraph:text global="false"}

Мы также предоставляем следующие предопределенные теги для использования:

По умолчанию все теги отображают одно и то же содержимое на каждой странице, использующей тип заголовка этого шаблона. Однако вы можете разрешить уникальное содержимое на каждой странице, указав атрибут global="false" . Например, если вы используете {subtitle:text} , по умолчанию все, что пользователь вводит для этого текста на одной странице, отображается на всех страницах, использующих тот же тип заголовка. Вместо этого, если вы установите его на global="false" , тогда они смогут устанавливать разные тексты на каждой странице.

Пользовательские теги

​Вы можете использовать приведенные ниже теги для создания областей с пользовательскими именами, в которые пользователи могут добавлять содержимое, не охватываемое предопределенными тегами. Замените имя области на более значимое слово.

Например, вы можете создать область для содержимого, специально предназначенного для информации о владельце веб-сайта. Вы можете создать тег {user-info:text} , и пользователь увидит Нажмите здесь, чтобы изменить .

Например:

 <дел>
    
{информация о пользователе:текст}
{адрес:текст}

​Вы также можете использовать атрибут global="false" для этих тегов. Не забудьте обновить свою таблицу стилей, чтобы стилизовать эти теги.

Область заголовка — это необязательная область заголовка, которую пользователь может настроить по мере необходимости. Когда пользователь нажимает на область заголовка, отображается всплывающее меню, и он может изменить фоновое изображение, цвет и, при желании, добавить видео (если на премиум-плане).

Область заголовка темы

Чтобы добавить область заголовка, добавьте тег {{#header}} в конце основного баннера-обертки div , как показано в следующем коде:

 
<дел> <дел>

{логотип

{меню
<дел> {меню} {{#заголовок}}
{контент}
{{/заголовок}}

​Используйте класс контейнера для стилизации по мере необходимости.

Добавить раздел

Разделы — это необязательные области, в которые пользователь может перетаскивать содержимое, позволяя страницам, использующим один и тот же шаблон, выглядеть совершенно по-разному, просто добавляя и создавая разделы. В случае с разделами, когда пользователь щелкает область основного содержимого, отображается всплывающее меню с вариантами оформления раздела. Пользователь также может перетащить синий контур, чтобы изменить высоту раздела.​ ​

Разделы позволяют пользователям добавлять контент в разные области

​Чтобы добавить раздел в шаблон, добавьте тег {{#sections}} , показанный в следующем коде, туда, где вы хотите, чтобы содержимое отображалось. Класс контейнера можно использовать для стилизации раздела, например, для установки максимальной ширины и центрирования разделов.

[ЗАГОЛОВНОЙ БЛОК]
{{#разделы}} <дел> {содержание}
{{/разделов}} [FOOTER BLOCK]

Большинство клиентов Weebly хотят, чтобы их веб-сайт работал на настольных и мобильных устройствах. Убедитесь, что вы правильно обрабатываете дисплеи на этих небольших экранах.


Помогите сделать эти документы лучше!

Была ли эта тема полезной? Нет ДаSorta
Комментарии или предложения?

Введите свое имя и адрес электронной почты, чтобы мы могли связаться с вами по поводу ваших комментариев.
Имя:
Электронная почта:
Я согласен, чтобы со мной связались


Теги:

Шаблоны | Документация Джанго | Django

Будучи веб-фреймворком, Django нуждается в удобном способе создания HTML динамически. Наиболее распространенный подход основан на шаблонах. Шаблон содержит статические части желаемого вывода HTML, а также некоторый специальный синтаксис описание того, как будет вставляться динамический контент. Для практического примера создание HTML-страниц с помощью шаблонов, см. Учебник 3.

Проект Django может быть настроен с одним или несколькими механизмами шаблонов (или даже ноль, если вы не используете шаблоны). Django поставляет встроенные серверные части для своих собственная система шаблонов, творчески названная языком шаблонов Django (DTL), и для популярной альтернативы Jinja2. Бэкенды для других языков шаблонов могут быть доступным от третьих лиц. Вы также можете написать свой собственный бэкенд, см. Пользовательский сервер шаблонов

Django определяет стандартный API для загрузки и рендеринга шаблонов независимо серверной части. Загрузка состоит из поиска шаблона для заданного идентификатора и его предварительная обработка, обычно компиляция в представление в памяти. Рендеринг означает интерполяцию шаблона с контекстными данными и возврат результирующая строка.

Язык шаблонов Django является собственным языком Django. система шаблонов. До Django 1.8 это была единственная доступная встроенная опция. Это хорошая библиотека шаблонов, несмотря на то, что она довольно самоуверенна и имеет несколько идиосинкразий. Если у вас нет веских причин выбрать другую серверной части, вам следует использовать DTL, особенно если вы пишете подключаемый приложение, и вы собираетесь распространять шаблоны. Вкладные приложения Django, которые включать шаблоны, такие как django.contrib.admin, использовать ДТЛ.

По историческим причинам как общая поддержка механизмов шаблонов, так и реализация языка шаблонов Django в реальном времени в django. template пространство имен.

Предупреждение

Система шаблонов не защищена от ненадежных авторов шаблонов. За например, сайт не должен позволять пользователям предоставлять свои собственные шаблоны, поскольку авторы шаблонов могут выполнять такие действия, как XSS-атаки и доступ свойства переменных шаблона, которые могут содержать конфиденциальную информацию.

Язык шаблонов Django

Синтаксис

Об этом разделе

Это обзор синтаксиса языка шаблонов Django. Подробнее см. справочник по синтаксису языка.

Шаблон Django — это текстовый документ или строка Python, размеченная с помощью Язык шаблонов Django. Некоторые конструкции распознаются и интерпретируются шаблонный движок. Основными из них являются переменные и теги.

Шаблон отображается с контекстом. Рендеринг заменяет переменные их значения, которые просматриваются в контексте, и выполняет теги. Все остальное выводится как есть.

Синтаксис языка шаблонов Django включает четыре конструкции.

Переменные

Переменная выводит значение из контекста, который представляет собой объект, подобный словарю. сопоставление ключей со значениями.

Переменные окружены {{ и }} вот так:

 Мое имя {{ first_name }}. Моя фамилия {{ last_name }}.
 

В контексте {'first_name': 'John', 'last_name': 'Doe'} этот шаблон рендерит на:

 Меня зовут Джон. Моя фамилия Доу.
 

Поиск по словарю, поиск по атрибуту и ​​поиск по списку-индексу реализованы с запись через точку:

 {{ my_dict.key }}
{{ мой_объект.атрибут }}
{{ мой_список.0 }}
 

Если переменная преобразуется в вызываемую, система шаблонов вызовет ее без аргументы и использовать его результат вместо вызываемого.

Теги

Теги обеспечивают произвольную логику в процессе рендеринга.

Это определение намеренно расплывчато. Например, тег может выводить контент, служить управляющей структурой, т.е. оператор «если» или цикл «для», возьмите контент из базы данных или даже включить доступ к другим тегам шаблона.

Теги окружены {% и %} вот так:

 {% csrf_token %}
 

Большинство тегов принимают аргументы:

 {% cycle 'odd' 'even' %}
 

Для некоторых тегов требуются начальный и конечный теги:

 {% if user.is_authenticated %}Здравствуйте, {{ user.username }}.{% endif %}
 

Ссылка на встроенные теги доступны, а также инструкции по написанию пользовательских тегов.

Фильтры

Фильтры преобразуют значения переменных и аргументов тегов.

Они выглядят так:

 {{ django|title }}
 

В контексте {'django': 'веб-фреймворк для перфекционистов с крайние сроки'} , этот шаблон преобразуется в:

 Веб-платформа для перфекционистов с крайними сроками
 

Некоторые фильтры принимают аргумент:

 {{ my_date|date:"Y-m-d" }}
 

Артикул встроенных фильтров доступны, а также инструкции по написанию пользовательских фильтров.

Компоненты

Об этом разделе

Это обзор API языка шаблонов Django. Подробнее см. справочник по API.

Engine

django.template.Engine инкапсулирует экземпляр Django система шаблонов. Основная причина создания экземпляра Engine напрямую использует шаблон Django. язык вне проекта Django.

django.template.backends.django.DjangoTemplates — тонкая оболочка адаптация django.template.Engine в бэкэнд API шаблонов Django.

Шаблон

django.template.Template представляет собой скомпилированный шаблон. Шаблоны получено с помощью Engine.get_template() или Engine.from_string() .

Аналогично django.template.backends.django.Template — тонкая оболочка адаптация django.template.Template к общему API шаблонов.

Контекст

django.template.Context содержит некоторые метаданные в дополнение к контексту данные. Он передан на Template.render() для рендеринга шаблона.

django.template.RequestContext является подклассом Контекст , в котором хранится текущий HttpRequest и запускает обработчики контекста шаблона.

Общий API не имеет эквивалентной концепции. Контекстные данные передаются в обычный dict и текущий HttpRequest передается отдельно, если нужно.

Загрузчики

Загрузчики шаблонов отвечают за поиск шаблонов, их загрузку и возвращение Шаблон объектов.

Django предоставляет несколько встроенных загрузчиков шаблонов и поддерживает пользовательские загрузчики шаблонов.

Контекстные процессоры

Контекстные процессоры — это функции, которые получают текущие HttpRequest в качестве аргумента и вернуть dict из данные, которые будут добавлены в контекст рендеринга.

Их основное назначение — добавить в контекст общие данные, используемые всеми шаблонами. без повторения кода в каждом представлении.

Django предоставляет множество встроенных контекстных процессоров, и вы также можете реализовать свои собственные дополнительные процессоры контекста.

Поддержка механизмов шаблонов

Конфигурация

Механизмы шаблонов настраиваются с помощью параметра ШАБЛОНЫ . Это список конфигураций, по одной для каждого двигателя. Значение по умолчанию пусто. settings.py , сгенерированный командой startproject , определяет более полезное значение:

 ШАБЛОНЫ = [
    {
        'БЭКЭНД': 'django.template.backends.django.DjangoTemplates',
        'КАТАЛОГИ': [],
        'APP_DIRS': правда,
        'ОПЦИИ': {
            # ... некоторые варианты здесь ...
        },
    },
]
 

BACKEND — путь Python к шаблону с точками. класс движка, реализующий бэкэнд API шаблонов Django. Встроенные серверные части django.template.backends.django.DjangoTemplates и django.template.backends. jinja2.Jinja2 .

Поскольку большинство механизмов загружают шаблоны из файлов, конфигурация верхнего уровня для каждый движок содержит две общие настройки:

Хотя это редкость, можно настроить несколько экземпляров одного и того же бэкэнд с различными опциями. В этом случае вы должны определить уникальный НАЗВАНИЕ для каждого двигателя.

ОПЦИИ содержит настройки, специфичные для серверной части.

Использование

Модуль django.template.loader определяет две функции для загрузки шаблонов.

get_template ( имя_шаблона , использование = Нет )

Эта функция загружает шаблон с заданным именем и возвращает Шаблон объекта.

Точный тип возвращаемого значения зависит от серверной части, которая загрузила шаблон. У каждого бэкенда есть свой собственный класс Template .

get_template() пробует каждый механизм шаблонов по порядку, пока не будет достигнут успех. Если шаблон не может быть найден, он поднимает Шаблон не существует . Если шаблон найден, но содержит неверный синтаксис, вызывает TemplateSyntaxError .

Способ поиска и загрузки шаблонов зависит от серверной части каждого механизма и конфигурация.

Если вы хотите ограничить поиск определенной системой шаблонов, передайте двигатель ИМЯ в с использованием аргумент.

select_template ( template_name_list , использование = Нет )

select_template() аналогичен get_template() , за исключением того, что он принимает список имен шаблонов. Он пробует каждое имя по порядку и возвращает первое существующий шаблон.

Если загрузка шаблона не удалась, следующие два исключения, определенные в django.template , можно поднять:

исключение TemplateDoesNotExist ( msg , пытался = нет , серверная часть = нет , цепочка = нет )

Это исключение возникает, когда не удается найти шаблон. Он принимает следующие необязательные аргументы для заполнения постмортема шаблона на странице отладки:

бэкэнд
Экземпляр бэкенда шаблона, из которого возникло исключение.
пытался
Список источников, которые были проверены при поиске шаблона. Это отформатирован как список кортежей, содержащих (происхождение, статус) , где origin — объект, похожий на origin, и статус — это строка с причиной, по которой шаблон не найден.
цепочка
Список промежуточных звеньев TemplateDoesNotExist исключения, возникающие при попытке загрузить шаблон. Это используется функции, такие как get_template() , что попробуйте загрузить данный шаблон из нескольких движков.
исключение TemplateSyntaxError ( сообщение )

Это исключение возникает, когда шаблон найден, но содержит ошибки.

Шаблон объектов, возвращенных get_template() и select_template() должен предоставить метод render() со следующей подписью:

Шаблон. рендеринг ( контекст = нет , запрос = нет )

Визуализирует этот шаблон с заданным контекстом.

Если предоставлен контекст , это должен быть dict . Если это не так при условии, что движок отобразит шаблон с пустым контекстом.

Если предоставлен запрос , это должен быть HttpRequest . Затем движок должен сделать его, а также токен CSRF, доступным в шаблон. Как это достигается, зависит от каждого бэкэнда.

Вот пример алгоритма поиска. Для этого примера ШАБЛОНЫ настройка:

 ШАБЛОНЫ = [
    {
        'БЭКЭНД': 'django.template.backends.django.DjangoTemplates',
        'КАТАЛОГИ': [
            '/home/html/example.com',
            '/дом/html/по умолчанию',
        ],
    },
    {
        'БЭКЭНД': 'django.template.backends.jinja2.Jinja2',
        'КАТАЛОГИ': [
            '/дом/html/джинджа2',
        ],
    },
]
 

Если вы позвоните get_template('story_detail.html') , вот файлы Django будем искать по порядку:

При вызове select_template(['story_253_detail.html', 'story_detail.html']) , вот что Django будет искать:

Когда Django находит существующий шаблон, он прекращает поиск.

Совет

Вы можете использовать select_template() для гибкого загрузка шаблона. Например, если вы написали новость и хотите некоторые истории, чтобы иметь собственные шаблоны, используйте что-то вроде select_template(['story_%s_detail. html' % story.id, 'story_detail.html']) . Это позволит вам использовать собственный шаблон для отдельной истории с запасным шаблоном для историй, у которых нет пользовательские шаблоны.

Возможно и желательно организовать шаблоны в подкаталогах внутри каждого каталога, содержащего шаблоны. Конвенция состоит в том, чтобы сделать подкаталог для каждого приложения Django с подкаталогами внутри этих подкаталоги по мере необходимости.

Сделай это для собственного рассудка. Хранение всех шаблонов на корневом уровне один каталог становится грязным.

Чтобы загрузить шаблон, находящийся в подкаталоге, используйте косую черту, например:

 get_template('news/story_detail.html')
 

При использовании той же опции ШАБЛОНЫ , что и выше, это попытается загрузить следующие шаблоны:

Кроме того, чтобы сократить повторяющийся характер загрузки и рендеринга шаблоны, Django предоставляет функцию быстрого доступа, которая автоматизирует процесс.

render_to_string ( имя_шаблона , контекст = нет , запрос = нет , использование = нет )

render_to_string() загружает шаблон, например get_template() и вызывает его render() 9Метод 0052 немедленно. Требуется следующее аргументы.

имя_шаблона
Имя шаблона для загрузки и отображения. Если это список шаблонов имена, Django использует select_template() вместо get_template() , чтобы найти шаблон.
context
dict , который будет использоваться в качестве контекста шаблона для рендеринга.
запрос
Необязательный HttpRequest , который будет доступен в процессе рендеринга шаблона.
с использованием
Дополнительный механизм шаблонов ИМЯ . поиск шаблона будет ограничен этим движком.

Пример использования:

 из импорта django.template.loader render_to_string
rendered = render_to_string('my_template.html', {'foo': 'bar'})
 

См. также ярлык render() , который вызывает render_to_string() и передает результат в HttpResponse подходит для возврата из представления.

Наконец, вы можете использовать настроенные двигатели напрямую:

двигатели

Механизмы шаблонов доступны в django.template.engines :

 из механизмов импорта django.template
django_engine = двигатели['django']
template = django_engine.from_string("Привет, {{имя}}!")
 

Ключ поиска — 'django' в данном примере — это ключ ИМЯ .

Встроенные серверные части

класс DjangoTemplates

Установите BACKEND на 'django.template.backends.django.DjangoTemplates' для настройки Django шаблонный движок.

Когда APP_DIRS равно True , DjangoTemplates двигатели ищут шаблоны в подкаталоге templates установленных Приложения. Это общее имя было сохранено для обратной совместимости.

Механизмы DjangoTemplates принимают следующие OPTIONS :

класс Джинджа2

Требуется установка Jinja2:

/

 $ python -m pip установить Jinja2
 
 ...\> py -m pip установить Jinja2
 

Установить БЭКЭНД на 'django.template.backends.jinja2.Jinja2' для настройки движка Jinja2.

Когда APP_DIRS равно True , Jinja2 двигателей ищите шаблоны в подкаталоге jinja2 установленных приложений.

Самая важная запись в ОПЦИИ 'окружающая среда' . Это пунктирный путь Python к вызываемому объекту, возвращающему Jinja2. среда. По умолчанию 'jinja2.Окружающая среда' . Джанго вызывает это callable и передает другие параметры в качестве аргументов ключевого слова. Кроме того, Джанго добавляет значения по умолчанию, которые отличаются от Jinja2 для нескольких параметров:

Механизмы Jinja2 также принимают следующие ОПЦИИ :

Конфигурация по умолчанию намеренно сведена к минимуму. Если шаблон отображается с запросом (например, при использовании рендер() ), серверная часть Jinja2 добавляет глобальные переменные request , csrf_input и csrf_token в контекст. Кроме того, этот бэкэнд не создает Среда со вкусом Джанго. Он не знает о фильтрах и тегах Django. Чтобы использовать специфичные для Django API, вы должны настроить их в среда.

Например, вы можете создать myproject/jinja2. py с таким содержимым:

 из django.templatetags.static import static
из django.urls импортировать в обратном порядке
из среды импорта jinja2
среда определения (** параметры):
    env = Окружающая среда (** параметры)
    env.globals.update({
        «статический»: статический,
        'адрес': обратный,
    })
    вернуть окружение
 

и установите для параметра 'environment' значение 'myproject.jinja2.environment' .

Затем вы можете использовать следующие конструкции в шаблонах Jinja2:

 Company Logo
Администрирование
 

Концепции тегов и фильтров существуют как в языке шаблонов Django, и в Jinja2, но они используются по-разному. Так как Jinja2 поддерживает передачу аргументы для вызываемых объектов в шаблонах, многие функции, требующие тега шаблона или фильтр в шаблонах Django можно получить, вызвав функцию в Jinja2 шаблоны, как показано в примере выше.

Оставить комментарий

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *