Os templates definem a apresentação do seu site, descrevendo o que cada página deve ter de semelhante. A tabela abaixo mostra o modelo correspondente para cada página disponível. No mínimo, um tema deve conter um template de index
.
Template | Página | Fallback |
---|---|---|
index |
Página Home | |
post |
Postagens | index |
page |
Páginas | index |
archive |
Arquivos (archives) | index |
category |
Categorias | archive |
tag |
Tags | archive |
Layouts
Quando as páginas compartilham uma estrutura semelhante - por exemplo, quando dois templates possuem um cabeçalho e um rodapé - você pode considerar usar um layout
para declarar essas semelhanças estruturais. Todo arquivo de layout deve conter uma variável body
para exibir o conteúdo do template em questão. Por exemplo:
index |
|
yields:
|
Por padrão, o template de layout
é usado por todos os outros templates. Você pode especificar layouts adicionais no front-matter ou configurá-lo como false
para desativá-lo. É até possível criar uma estrutura aninhada complexa ao incluir mais templates de layout no seu layout principal.
Partials
Os partials são úteis para compartilhar componentes entre seus templates. Um exemplo típico inclui cabeçalhos (header), rodapés (footer) ou barras laterais (sidebar). Você pode querer colocar seus partials em arquivos separados para tornar a manutenção do seu site significativamente mais conveniente. Por exemplo:
<h1 id="logo"><%= config.title %></h1> |
<%- partial('partial/header') %> |
yields:
<h1 id="logo">My Site</h1> |
Variáveis Locais
Você pode definir variáveis locais em um template e usá-las em outros templates.
<h1 id="logo"><%= title></h1> |
<%- partial('partial/header', {title: 'Hello World'}) %> |
yields:
<h1 id="logo">Hello World</h1> |
Otimização
Se o seu tema for extremamente complexo ou se o número de arquivos a serem gerados for muito grande, o desempenho da geração de arquivos do Hexo pode começar a diminuir consideravelmente. Além de simplificar o seu tema, você também pode tentar usar o Fragment Caching
, que foi introduzido no Hexo 2.7.
Este recurso foi emprestado do Ruby on Rails. Isso faz com que o conteúdo seja salvo de forma fragmentada e cacheado para quando requisições adicionais forem feitas. Isso pode reduzir o número de consultas no banco de dados e também pode acelerar a geração de arquivos.
O recurso de Fragment Caching
é melhor aproveitado em cabeçalhos, rodapés, barras laterais e outros conteúdos estáticos, onde sejam feitas pouquíssimas mudanças de um template para outro. Por exemplo:
<%- fragment_cache('header', function(){ |
Embora seja mais fácil usar partials:
<%- partial('header', {}, {cache: true}); |
Não use o Fragment Caching
quando a configuração de relative_link
estiver habilitada. Isso pode causar problemas porque os links relativos podem e provavelmente serão diferentes dependendo das páginas em que aparecem.