Grav - Pages
In questo capitolo, studiamo Grav Pages. Le pagine possono essere definite come elementi costitutivi del sito. Le pagine combinano contenuti e navigazioni; questo rende il lavoro più facile anche per gli utenti inesperti.
Per cominciare, facci sapere come creare una semplice pagina. Tutti i contenuti dell'utente verranno archiviati inuser/pages/cartella. Ci sarà solo una cartella chiamata01.home. La parte numerica della cartella è facoltativa; esprime l'ordine delle tue pagine (ad esempio, 01 verrà prima di 02) e informa esplicitamente Grav che questa pagina dovrebbe essere visibile nel menu.
Vediamo ora come creare una nuova pagina.
Step 1 - Crea una cartella in /user/pages/; per esempio, 02.about come mostrato nello screenshot seguente.
Step 2 - Crea un file chiamato default.md all'interno del nuovo creato 02.about cartella con il seguente contenuto.
---
title: About Us
---
# About Us Page!
This is the body of **about us page**.
Il codice sopra ne usa alcuni Markdownsintassi spiegata brevemente di seguito. Puoi studiare in dettaglio suMarkdownnel capitolo Markdown .
Il contenuto tra gli indicatori --- è il file Page Headers.
# o hashes sintassi in Markdown indica un titolo che verrà convertito in <h1> intestazione in HTML.
** i marcatori indicano il testo in grassetto o <b> in HTML.
Step 3 - Ricarica il browser e puoi vedere la nuova pagina nel menu come mostrato nello screenshot seguente.
Tipi di pagina
Grav Pages supporta 3 tipi di pagine:
- Pagina standard.
- Pagina di elenco.
- Pagina modulare.
Pagina standard
Le pagine standard sono il tipo più elementare di pagine come post del blog, modulo di contatto, pagina di errore, ecc. Per impostazione predefinita, una pagina è considerata una pagina standard. Sarai accolto da una pagina standard non appena scarichi e installi il pacchetto Base Grav. Vedrai la pagina seguente quando installi il pacchetto Base Grav.
Pagina di elenco
La pagina di elenco è un'estensione di una pagina standard che ha un riferimento a una raccolta di pagine. Il modo più semplice per impostare la pagina dell'elenco è creare pagine figlie sotto la pagina dell'elenco. Una pagina di elenco di blog è un ottimo esempio per questo.
Uno scheletro di blog di esempio con una pagina di elenco può essere trovato nei download di Grav . Uno di esempio è mostrato nello screenshot seguente.
Pagina modulare
La pagina modulare è una forma di pagina di elenco che costruisce una singola pagina dalle sue pagine figlie. Questo ci consente di creare layout di una pagina molto complessi da pagine di contenuto modulare più piccole. Ciò può essere ottenuto costruendo la pagina modulare da più cartelle modulari presenti nella cartella principale della pagina.
Uno scheletro di una pagina di esempio che utilizza una pagina modulare può essere trovato nei download di Grav . Uno di esempio è mostrato nello screenshot seguente.
Cartelle
Il /user/pagescartella conterrà i contenuti delle rispettive pagine. Le cartelle all'interno del file/user/pagesle cartelle vengono automaticamente trattate come menu da Grav e utilizzate ai fini dell'ordine. Ad esempio, il file01.homela cartella verrà considerata come home. Anche l'ordinazione deve essere mantenuta, ovvero 01.home arriverà prima del 02.about.
Dovresti fornire un punto di ingresso in modo che specifichi il browser dove andare quando punti il browser alla radice del tuo sito. Ad esempio, se inserisci http://mysite.com nel tuo browser, Grav si aspetta un aliashome/ per impostazione predefinita, ma puoi sovrascrivere la posizione della casa modificando il file home.alias opzione nel file di configurazione Grav.
Il carattere di sottolineatura (_) prima che il nome della cartella venga identificato come Modular folders, che è un tipo di cartella speciale che deve essere utilizzato solo lungo il contenuto modulare. Ad esempio, per la cartella comepages/02.about, slug verrà impostato automaticamente su aboute l'URL sarà http://mysite.com/about.
Se il nome della cartella non è preceduto da numeri, quella pagina è considerata invisibile e non verrà visualizzata nella navigazione. Ad esempio, il file ifuser/pages/ ha /contactcartella, non verrà visualizzato nella navigazione. Questo può essere sovrascritto nella pagina stessa all'interno della sezione dell'intestazione impostando visibile su vero come mostrato di seguito per renderlo visibile nella navigazione.
---
title: contact
visible: true
---
Per impostazione predefinita, una pagina è visibile nella navigazione se le cartelle circostanti hanno prefissi numerici. I valori validi per l'impostazione della visibilità sono true o false.
Ordinazione
Esistono molti modi per controllare l'ordinamento della cartella, uno dei modi più importanti è impostare content.order.bydelle impostazioni di configurazione della pagina. Le opzioni sono elencate di seguito.
default - Il file system può essere utilizzato per l'ordinazione, ovvero 01.home prima di 02.about.
title - Il titolo può essere utilizzato per l'ordinamento definito in ogni pagina.
date - L'ordine può essere basato sulla data definita in ogni pagina.
folder - Il nome della cartella costituito da qualsiasi prefisso numerico, ad esempio 01., verrà rimosso.
basename - L'ordinamento si basa sulla cartella alfabetica senza ordine numerico.
modified - È possibile utilizzare anche il timestamp modificato della pagina.
header.x - Qualsiasi campo dell'intestazione della pagina può essere utilizzato per l'ordinazione.
manual - Utilizzando order_manual è possibile effettuare l'ordinamento delle variabili.
random - Puoi anche randomizzare il tuo ordine.
L'ordine manuale viene definito in modo specifico fornendo un elenco di opzioni al file content.order.customimpostazione di configurazione. Puoi impostare il filepages.order.dir e il pages.order.by opzioni per sovrascrivere il comportamento predefinito nel file di configurazione del sistema Grav.
File di testo
La pagina all'interno della cartella della pagina dovrebbe essere creata come .mdfile, cioè file formattato Markdown; è un ribasso con la materia anteriore di YAML. Ildefaultsarà il nome standard per il modello principale e puoi dargli qualsiasi nome. Di seguito è riportato un esempio per una pagina semplice:
---
title: Title of the page
taxonomy:
category: blog page
---
# Title of the page
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque porttitor eu
felis sed ornare. Sed a mauris venenatis, pulvinar velit vel, dictum enim. Phasellus
ac rutrum velit. **Nunc lorem** purus, hendrerit sit amet augue aliquet, iaculis
ultricies nisl. Suspendisse tincidunt euismod risus. Nunc a accumsan purus.
I contenuti tra i marcatori --- sono conosciuti come frontespizio YAML e questo frontespizio YAML consiste nelle impostazioni YAML di base. Nell'esempio sopra, stiamo impostando il titolo e la tassonomia della pagina del blog. La sezione dopo la coppia di indicatori --- è il contenuto effettivo che vediamo sul nostro sito.
Dimensione riepilogo e separatore
La dimensione predefinita del riepilogo può essere impostata in site.yaml utilizzato tramite page.summary(). Ciò è utile per i blog in cui sono necessarie solo le informazioni di riepilogo e non il contenuto della pagina intera. Puoi usare il filemanual summary separator conosciuto anche come summary delimiter: === e assicurati di inserirlo nel tuo contenuto con righe vuote sopra e sotto, come mostrato di seguito.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua.
===
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt
ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in
reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur
sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id
est laborum."
Il testo sopra il separatore verrà utilizzato quando referenziato da page.summary() e il contenuto completo se referenziato da page.content().
Trovare altre pagine
Grav ha una funzione chiamata find() metodo per trovare un'altra pagina ed eseguire azioni su quella pagina.
Ad esempio, se desideri elencare tutte le sedi dell'azienda in una determinata pagina, utilizza la seguente regola di ribasso:
# Locations
<ul>
{% for loc in page.find('/locations').children if loc != page %}
<li><a href="{{loc.url}}">{{ loc.title }}</a></li>
{% endfor %}
</ul>