Snippets
Manchmal möchte mal Elemente wiederhole oder ein eigenes Element erstellen, um z.B. weniger schreiben zu müssen. Snippets erlauben genau das.
Snippets müssen im Ordner snippets
neben dem book
und glossary
Ordner platziert werden. Sie haben die Endung .md.hbs
.
Beispiel
Beispiel 1: Block
Hier ist ein einfaches Beispiel eines Snippets für einen geschützen Bereich mit demselben Passwort.
Das Snippet ist platziert in templates/password.md.hbs
:
Diesen Markdown-Block musst du in deinem Hyperbook platzieren.
Das ist das Ergebnis:
😃
Example 2: Block mit Parameter
Du kannst auch Parameter für deine Snippets definieren, um sie dynamisch zu machen. Zum Beispiel kann man userem Passwort-Snippet den hint-Parameter übergeben. Wenn dieser übergeben wird, dann wird ein Hinweis gezeigt.
Hyperbook is the password.
Example 3: Im Text
Wir sind zehn Smilies: 😃 😃 😃 😃 😃 😃 😃 😃 😃 😃
Parameter
Du kannst Parameter in deinem Snippet verwenden, indem du geschweifte Klammern benutzt.
Drei geschweifte Klammern geben den rohen Inhalt wieder.
Zwei geschweifte Klammern den HTML-escapten Inhalt.
Inhalt
Wenn dein Snippet über mehrere Zeilen geht, kannst du den content-Parameter benutzen. Siehe Beispiel 1.
Du solltest drei geschweifte Klammern um den content-Parameter setzen.
Helpers
Du kannst die folgenden Helfer in deinem Snippet verwenden.
if
Verwende if, um Blöcke anhand einer Bedingung anzuzeigen.
unless
Verwende unless, wenn du das gegenteil von if möchtest.
times
Verwende times, wenn du einen Block mehrmals angezeigt haben möchtest.
file
Verwende file, wenn du den Inhalt einer anderen Datei einbinden möchtest.
Du kannst außerdem auch nur ausgewählte Zeilen einbinden.
Und du kannst definieren, ob ein Ausblendungssymbol gezeigt werden soll.
base64
Du kannst auch Mediendateien einbetten.
Dies funktioniert am besten mit dem image Block:
concat
Hi there
camelcase
thisIsATest
pascalcase
ThisIsATest
dashcase
This-is-a-test
lowercase
this is a test
uppercase
THIS IS A TEST
replace
Give me Apple Banana
replaceAll
Give me Apple Apple