title | category | prism_languages | updated | weight | tags | ||
---|---|---|---|---|---|---|---|
Pug |
JavaScript libraries |
|
2017-10-30 |
-3 |
|
{: .-three-column}
{: .-prime}
doctype html
html(lang='en')
h1.class#id(name='hi')
| This is some text, hello there,
= name
- javascript()
div
| Just a div
.search
| A div, with class 'search'
h1 A heading with text
h1= page.title
div.class
div.class1.class2
h1.header
input(type='text' name='q' autofocus)
- var authenticated = true
body(class=authenticated ? 'authed' : 'anon')
See: Attributes
// This comment will appear in the HTML
//- This is a silent comment
//-
Nesting inside a comment creates
a comment block
See: Comments
ul
each user in users
li= user
//- page.pug
extends layout.pug
block title
| hello
block content
| hello
//- layout.pug
title
block title
body
block content
include ./includes/head.pug
include:markdown article.md
See: Includes
p.
This is text that doesn't need to
be prefixed by pipes.
{: data-line="1"}
script.
// It's great for raw
// JavaScript and stuff
alert('hello')
{: data-line="1"}
if authenticated
a(href='/logout') Sign out
else
a(href='/login') Sign in
{: data-line="1,3"}
See: Conditionals
{: .-three-column}
mixin list
ul
···
{: data-line="1"}
+list
Mixins allow you to create reusable code blocks. See: Mixins
mixin pet(name)
span.pet= name
{: data-line="1"}
+pet('cat')
See: Mixin attributes
mixin article(title)
article
h2.title= title
block
{: data-line="1,4"}
+article('hello there')
p Content goes here
See: Mixin blocks