mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2025-01-15 05:35:59 +00:00
209 lines
4.0 KiB
Markdown
209 lines
4.0 KiB
Markdown
---
|
|
language: Pug
|
|
contributors:
|
|
- ["Michael Warner", "https://github.com/MichaelJGW"]
|
|
filename: lernepug-de.pug
|
|
translators:
|
|
- ["denniskeller", "https://github.com/denniskeller"]
|
|
lang: de-de
|
|
---
|
|
|
|
## Erste Schritte mit Pug
|
|
|
|
Pug ist eine kleine Sprache, die zu HTML kompiliert. Sie hat eine
|
|
saubere Syntax mit zusätzlichen Funktionen wie if Anweisungen und Schleifen.
|
|
Sie kann auch als serverseitige Templatingsprache für Serversprachen
|
|
wie NodeJS verwendet werden.
|
|
|
|
### Die Sprache
|
|
```pug
|
|
|
|
//- Einzeilenkommentar
|
|
|
|
//- Mehrzeiliger
|
|
Kommentar
|
|
|
|
//- ---TAGS---
|
|
//- Grundlagen
|
|
div
|
|
//- <div></div>
|
|
h1
|
|
//- <h1></h1>
|
|
mein-benutzerdefiniertesTag
|
|
//- <mein-benutzerdefiniertesTag></mein-benutzerdefiniertesTag>
|
|
|
|
//- Geschwister
|
|
div
|
|
div
|
|
//- <div></div>
|
|
<div></div>
|
|
|
|
//- Kind
|
|
div
|
|
div
|
|
//- <div>
|
|
<div></div>
|
|
</div>
|
|
|
|
//- Text
|
|
h1 Hallo Welt
|
|
//- <h1>Hallo Welt</h1>
|
|
|
|
//- Multizeilentext
|
|
div.
|
|
Hallo
|
|
Welt
|
|
//- <div>
|
|
Hallo
|
|
Welt
|
|
</div>
|
|
|
|
//- ---ATTRIBUTE---
|
|
div(class="meine-klasse" id="meine-id" mein-benutzerdefiniertes-attr="data" enabled)
|
|
//- <div class="meine-klasse" id="meine-id" mein-benutzerdefiniertes-attr="data" enabled></div>
|
|
|
|
//- Kurzhand
|
|
span.meine-klasse
|
|
//- <span class="meine-klasse"></span>
|
|
.meine-klasse
|
|
//- <div class="meine-klasse"></div>
|
|
div#meine-id
|
|
//- <div id="meine-id"></div>
|
|
div#meine-id.meine-klasse
|
|
//- <div class="meine-klasse" id="meine-id"></div>
|
|
|
|
|
|
//- ---JS---
|
|
- const sprache = "pug";
|
|
|
|
//- Multizeilen JS
|
|
-
|
|
const srache = "pug";
|
|
const cool = true;
|
|
|
|
//- JS Klassen
|
|
- const meineKlasse = ['class1', 'class2', 'class3']
|
|
div(class=meineKlasse)
|
|
//- <div class="class1 class2 class3"></div>
|
|
|
|
//- JS Stil
|
|
- const meineStile = {'color':'white', 'background-color':'blue'}
|
|
div(styles=meineStile)
|
|
//- <div styles="{"color":"white","background-color":"blue"}"></div>
|
|
|
|
//- JS Attributte
|
|
- const meineAttribute = {"src": "foto.png", "alt": "meine Bilder"}
|
|
img&attributes(meineAttribute)
|
|
//- <img src="foto.png" alt="meine Bilder">
|
|
- let deaktiviert = false
|
|
input(type="text" disabled=deaktiviert)
|
|
//- <input type="text">
|
|
- deaktiviert = true
|
|
input(type="text" disabled=deaktiviert)
|
|
//- <input type="text" disabled>
|
|
|
|
//- JS Templating
|
|
- const name = "Bob";
|
|
h1 Hi #{name}
|
|
h1= name
|
|
//- <h1>Hi Bob</h1>
|
|
//- <h1>Bob</h1>
|
|
|
|
//- ---Schleifen---
|
|
|
|
//- 'each' und 'for' machen das Selbe. Wir werden nur 'each' verwenden.
|
|
|
|
each value, i in [1,2,3]
|
|
p=value
|
|
//-
|
|
<p>1</p>
|
|
<p>2</p>
|
|
<p>3</p>
|
|
|
|
each value, index in [1,2,3]
|
|
p=value + '-' + index
|
|
//-
|
|
<p>1-0</p>
|
|
<p>2-1</p>
|
|
<p>3-2</p>
|
|
|
|
each value in []
|
|
p=value
|
|
//-
|
|
|
|
each value in []
|
|
p=value
|
|
else
|
|
p Keine Werte sind hier
|
|
|
|
//- <p>Keine Werte sind hier</p>
|
|
|
|
//- ---BEDINGUNGEN---
|
|
|
|
- const zahl = 5
|
|
if zahl < 5
|
|
p zahl ist kleiner als 5
|
|
else if zahl > 5
|
|
p zahl ist größer als 5
|
|
else
|
|
p zahl ist 5
|
|
//- <p>zahl ist 5</p>
|
|
|
|
- const bestellungsStatus = "Ausstehend";
|
|
case bestellungsStatus
|
|
when "Ausstehend"
|
|
p.warn Deine Bestellung steht noch aus
|
|
when "Abgeschlossen"
|
|
p.success Bestellung ist abgeschlossen.
|
|
when -1
|
|
p.error Ein Fehler ist aufgetreten
|
|
default
|
|
p kein Bestellprotokoll gefunden
|
|
//- <p class="warn">Deine Bestellung steht noch aus</p>
|
|
|
|
//- --INCLUDE--
|
|
//- File path -> "includes/nav.png"
|
|
h1 Firmenname
|
|
nav
|
|
a(href="index.html") Home
|
|
a(href="about.html") Über uns
|
|
|
|
//- Dateipfad -> "index.png"
|
|
html
|
|
body
|
|
include includes/nav.pug
|
|
//-
|
|
<html>
|
|
<body>
|
|
<h1>Firmenname</h1>
|
|
<nav><a href="index.html">Home</a><a href="about.html">Über uns</a></nav>
|
|
</body>
|
|
</html>
|
|
|
|
//- Importiere JS und CSS
|
|
script
|
|
include scripts/index.js
|
|
style
|
|
include styles/theme.css
|
|
|
|
//- ---MIXIN---
|
|
mixin basic()
|
|
div Hallo
|
|
+basic("Bob")
|
|
//- <div>Hallo</div>
|
|
|
|
mixin comment(name, kommentar)
|
|
div
|
|
span.comment-name= name
|
|
div.comment-text= kommentar
|
|
+comment("Bob", "Das ist super")
|
|
//- <div>Hallo</div>
|
|
|
|
```
|
|
|
|
|
|
### Zusätzliche Ressourcen
|
|
- [The Site](https://pugjs.org/)
|
|
- [The Docs](https://pugjs.org/api/getting-started.html)
|
|
- [Github Repo](https://github.com/pugjs/pug)
|