\documentclass[10pt,a4paper]{article} % Packages \usepackage{fancyhdr} % For header and footer \usepackage{multicol} % Allows multicols in tables \usepackage{tabularx} % Intelligent column widths \usepackage{tabulary} % Used in header and footer \usepackage{hhline} % Border under tables \usepackage{graphicx} % For images \usepackage{xcolor} % For hex colours %\usepackage[utf8x]{inputenc} % For unicode character support \usepackage[T1]{fontenc} % Without this we get weird character replacements \usepackage{colortbl} % For coloured tables \usepackage{setspace} % For line height \usepackage{lastpage} % Needed for total page number \usepackage{seqsplit} % Splits long words. %\usepackage{opensans} % Can't make this work so far. Shame. Would be lovely. \usepackage[normalem]{ulem} % For underlining links % Most of the following are not required for the majority % of cheat sheets but are needed for some symbol support. \usepackage{amsmath} % Symbols \usepackage{MnSymbol} % Symbols \usepackage{wasysym} % Symbols %\usepackage[english,german,french,spanish,italian]{babel} % Languages % Document Info \author{deftcode} \pdfinfo{ /Title (deftcode-emmet.pdf) /Creator (Cheatography) /Author (deftcode) /Subject (DeftCode Emmet Cheat Sheet) } % Lengths and widths \addtolength{\textwidth}{6cm} \addtolength{\textheight}{-1cm} \addtolength{\hoffset}{-3cm} \addtolength{\voffset}{-2cm} \setlength{\tabcolsep}{0.2cm} % Space between columns \setlength{\headsep}{-12pt} % Reduce space between header and content \setlength{\headheight}{85pt} % If less, LaTeX automatically increases it \renewcommand{\footrulewidth}{0pt} % Remove footer line \renewcommand{\headrulewidth}{0pt} % Remove header line \renewcommand{\seqinsert}{\ifmmode\allowbreak\else\-\fi} % Hyphens in seqsplit % This two commands together give roughly % the right line height in the tables \renewcommand{\arraystretch}{1.3} \onehalfspacing % Commands \newcommand{\SetRowColor}[1]{\noalign{\gdef\RowColorName{#1}}\rowcolor{\RowColorName}} % Shortcut for row colour \newcommand{\mymulticolumn}[3]{\multicolumn{#1}{>{\columncolor{\RowColorName}}#2}{#3}} % For coloured multi-cols \newcolumntype{x}[1]{>{\raggedright}p{#1}} % New column types for ragged-right paragraph columns \newcommand{\tn}{\tabularnewline} % Required as custom column type in use % Font and Colours \definecolor{HeadBackground}{HTML}{333333} \definecolor{FootBackground}{HTML}{666666} \definecolor{TextColor}{HTML}{333333} \definecolor{DarkBackground}{HTML}{A3A3A3} \definecolor{LightBackground}{HTML}{F3F3F3} \renewcommand{\familydefault}{\sfdefault} \color{TextColor} % Header and Footer \pagestyle{fancy} \fancyhead{} % Set header to blank \fancyfoot{} % Set footer to blank \fancyhead[L]{ \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{C} \SetRowColor{DarkBackground} \vspace{-7pt} {\parbox{\dimexpr\textwidth-2\fboxsep\relax}{\noindent \hspace*{-6pt}\includegraphics[width=5.8cm]{/web/www.cheatography.com/public/images/cheatography_logo.pdf}} } \end{tabulary} \columnbreak \begin{tabulary}{11cm}{L} \vspace{-2pt}\large{\bf{\textcolor{DarkBackground}{\textrm{DeftCode Emmet Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{deftcode} via \textcolor{DarkBackground}{\uline{cheatography.com/36955/cs/11997/}}} \end{tabulary} \end{multicols}} \fancyfoot[L]{ \footnotesize \noindent \begin{multicols}{3} \begin{tabulary}{5.8cm}{LL} \SetRowColor{FootBackground} \mymulticolumn{2}{p{5.377cm}}{\bf\textcolor{white}{Cheatographer}} \\ \vspace{-2pt}deftcode \\ \uline{cheatography.com/deftcode} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 3rd June, 2017.\\ Updated 3rd June, 2017.\\ Page {\thepage} of \pageref{LastPage}. \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Sponsor}} \\ \SetRowColor{white} \vspace{-5pt} %\includegraphics[width=48px,height=48px]{dave.jpeg} Measure your website readability!\\ www.readability-score.com \end{tabulary} \end{multicols}} \begin{document} \raggedright \raggedcolumns % Set font size to small. Switch to any value % from this page to resize cheat sheet text: % www.emerson.emory.edu/services/latex/latex_169.html \footnotesize % Small font. \begin{multicols*}{2} \begin{tabularx}{8.4cm}{p{0.8 cm} x{7.2 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{Syntax}} \tn % Row 0 \SetRowColor{LightBackground} \textgreater{} & Child - `nav\textgreater{}ul\textgreater{}li` \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} + & Sibling - `div+p+bq` \tn % Row Count 2 (+ 1) % Row 2 \SetRowColor{LightBackground} \textasciicircum{} & Climb up - `div+div\textgreater{}p\textgreater{}span+em\textasciicircum{}bq` \tn % Row Count 3 (+ 1) % Row 3 \SetRowColor{white} ( ) & Grouping - `div\textgreater{}(header\textgreater{}ul\textgreater{}li*2\textgreater{}a)+footer\textgreater{}p` \tn % Row Count 5 (+ 2) % Row 4 \SetRowColor{LightBackground} * & Multiplication - `ul\textgreater{}li*5` \tn % Row Count 6 (+ 1) % Row 5 \SetRowColor{white} \$ & Numbering - `ul\textgreater{}li.item\$*5` \tn % Row Count 7 (+ 1) % Row 6 \SetRowColor{LightBackground} . & Class - `h1.title` or `p.class1.class2.class3` \tn % Row Count 9 (+ 2) % Row 7 \SetRowColor{white} \# & ID - `div.\#header` or `form\#search.wide` \tn % Row Count 11 (+ 2) % Row 8 \SetRowColor{LightBackground} {[} {]} & Custom attributes - `td{[}rowspan=2 colspan=3 title{]}` \tn % Row Count 13 (+ 2) % Row 9 \SetRowColor{white} \{ \} & Text - `p\textgreater{}\{Click \}+a\{here\}+\{ to continue\}` \tn % Row Count 15 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{1.76 cm} x{6.24 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{HTML}} \tn % Row 0 \SetRowColor{LightBackground} ! & Create HTML5 template \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} a & `\textless{}a href=""\textgreater{}\textless{}/a\textgreater{}` \tn % Row Count 2 (+ 1) % Row 2 \SetRowColor{LightBackground} a:link & `\textless{}a href="http://"\textgreater{}\textless{}/a\textgreater{}` \tn % Row Count 3 (+ 1) % Row 3 \SetRowColor{white} a:mail & `\textless{}a href="mailto:"\textgreater{}\textless{}/a\textgreater{}` \tn % Row Count 4 (+ 1) % Row 4 \SetRowColor{LightBackground} link & `\textless{}link rel="stylesheet" href="" /\textgreater{}` \tn % Row Count 6 (+ 2) % Row 5 \SetRowColor{white} meta & `\textless{}meta /\textgreater{}` \tn % Row Count 7 (+ 1) % Row 6 \SetRowColor{LightBackground} \seqsplit{meta:utf} & `\textless{}meta \seqsplit{http-equiv="Content-Type"} \seqsplit{content="text/html;charset=UTF-8"} /\textgreater{}` \tn % Row Count 10 (+ 3) % Row 7 \SetRowColor{white} style & `\textless{}style\textgreater{}\textless{}/style\textgreater{}` \tn % Row Count 11 (+ 1) % Row 8 \SetRowColor{LightBackground} script & `\textless{}script\textgreater{}\textless{}/script\textgreater{}` \tn % Row Count 12 (+ 1) % Row 9 \SetRowColor{white} \seqsplit{script:src} & `\textless{}script src=""\textgreater{}\textless{}/script\textgreater{}` \tn % Row Count 14 (+ 2) % Row 10 \SetRowColor{LightBackground} img & `\textless{}img src="" alt="" /\textgreater{}` \tn % Row Count 15 (+ 1) % Row 11 \SetRowColor{white} form & `\textless{}form action=""\textgreater{}\textless{}/form\textgreater{}` \tn % Row Count 16 (+ 1) % Row 12 \SetRowColor{LightBackground} \seqsplit{form:get} & `\textless{}form action="" method="get"\textgreater{}\textless{}/form\textgreater{}` \tn % Row Count 18 (+ 2) % Row 13 \SetRowColor{white} \seqsplit{form:post} & `\textless{}form action="" method="post"\textgreater{}\textless{}/form\textgreater{}` \tn % Row Count 20 (+ 2) % Row 14 \SetRowColor{LightBackground} label & `\textless{}label for=""\textgreater{}\textless{}/label\textgreater{}` \tn % Row Count 21 (+ 1) % Row 15 \SetRowColor{white} inp & `\textless{}input type="text" name="" id="" /\textgreater{}` \tn % Row Count 23 (+ 2) % Row 16 \SetRowColor{LightBackground} \seqsplit{input:email} & `\textless{}input type="email" name="" id="" /\textgreater{}` \tn % Row Count 25 (+ 2) % Row 17 \SetRowColor{white} input:p & `\textless{}input type="password" name="" id="" /\textgreater{}` \tn % Row Count 27 (+ 2) % Row 18 \SetRowColor{LightBackground} input:c & `\textless{}input type="checkbox" name="" id="" /\textgreater{}` \tn % Row Count 29 (+ 2) % Row 19 \SetRowColor{white} input:r & `\textless{}input type="radio" name="" id="" /\textgreater{}` \tn % Row Count 31 (+ 2) \end{tabularx} \par\addvspace{1.3em} \vfill \columnbreak \begin{tabularx}{8.4cm}{x{1.76 cm} x{6.24 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{HTML (cont)}} \tn % Row 20 \SetRowColor{LightBackground} input:f & `\textless{}input type="file" name="" id="" /\textgreater{}` \tn % Row Count 2 (+ 2) % Row 21 \SetRowColor{white} select & `\textless{}select name="" id=""\textgreater{}\textless{}/select\textgreater{}` \tn % Row Count 4 (+ 2) % Row 22 \SetRowColor{LightBackground} option & `\textless{}option value=""\textgreater{}\textless{}/option\textgreater{}` \tn % Row Count 5 (+ 1) % Row 23 \SetRowColor{white} \seqsplit{textarea} & `\textless{}textarea name="" id="" cols="30" rows="10"\textgreater{}\textless{}/textarea\textgreater{}` \tn % Row Count 7 (+ 2) % Row 24 \SetRowColor{LightBackground} btn:s & `\textless{}button type="submit"\textgreater{}\textless{}/button\textgreater{}` \tn % Row Count 9 (+ 2) % Row 25 \SetRowColor{white} btn & `\textless{}button\textgreater{}\textless{}/button\textgreater{}` \tn % Row Count 10 (+ 1) % Row 26 \SetRowColor{LightBackground} sect & `\textless{}section\textgreater{}\textless{}/section\textgreater{}` \tn % Row Count 11 (+ 1) % Row 27 \SetRowColor{white} art & `\textless{}article\textgreater{}\textless{}/article\textgreater{}` \tn % Row Count 12 (+ 1) % Row 28 \SetRowColor{LightBackground} hdr & `\textless{}header\textgreater{}\textless{}/header\textgreater{}` \tn % Row Count 13 (+ 1) % Row 29 \SetRowColor{white} ftr & `\textless{}footer\textgreater{}\textless{}/footer\textgreater{}` \tn % Row Count 14 (+ 1) % Row 30 \SetRowColor{LightBackground} mn & `\textless{}main\textgreater{}\textless{}/main\textgreater{}` \tn % Row Count 15 (+ 1) % Row 31 \SetRowColor{white} ol+ & `\textless{}ol\textgreater{}\{\{nl\}\}~~\textless{}li\textgreater{}\textless{}/li\textgreater{}\{\{nl\}\}\textless{}/ol\textgreater{}` \tn % Row Count 17 (+ 2) % Row 32 \SetRowColor{LightBackground} ul+ & `\textless{}ul\textgreater{}\{\{nl\}\}~~\textless{}li\textgreater{}\textless{}/li\textgreater{}\{\{nl\}\}\textless{}/ul\textgreater{}` \tn % Row Count 19 (+ 2) % Row 33 \SetRowColor{white} dl+ & `\textless{}ol\textgreater{}\{\{nl\}\}~~\textless{}dt\textgreater{}\textless{}/dt\textgreater{}\{\{nl\}\}~~\textless{}dd\textgreater{}\textless{}/dd\textgreater{}\{\{nl\}\}\textless{}/ol\textgreater{}` \tn % Row Count 22 (+ 3) % Row 34 \SetRowColor{LightBackground} table+ & `\textless{}table\textgreater{}\{\{nl\}\}~~\textless{}tr\textgreater{}\{\{nl\}\}~~~~\textless{}td\textgreater{}\textless{}/td\textgreater{}\{\{nl\}\}~~\textless{}/tr\textgreater{}\{\{nl\}\}\textless{}/table\textgreater{}` \tn % Row Count 26 (+ 4) % Row 35 \SetRowColor{white} tr+ & `\textless{}tr\textgreater{}\{\{nl\}\}~~\textless{}td\textgreater{}\textless{}/td\textgreater{}\{\{nl\}\}\textless{}/tr\textgreater{}` \tn % Row Count 28 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{8.4cm}{x{2.8 cm} x{5.2 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{CSS}} \tn % Row 0 \SetRowColor{LightBackground} pos:(a|r|f) & \seqsplit{`position:absolute|relative|fixed;`} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} t & `top` \tn % Row Count 3 (+ 1) % Row 2 \SetRowColor{LightBackground} r & `right` \tn % Row Count 4 (+ 1) % Row 3 \SetRowColor{white} b & `bottom` \tn % Row Count 5 (+ 1) % Row 4 \SetRowColor{LightBackground} l & `left` \tn % Row Count 6 (+ 1) % Row 5 \SetRowColor{white} z & `z-index` \tn % Row Count 7 (+ 1) % Row 6 \SetRowColor{LightBackground} fl:(n|r|l) & `float:none|right|left;` \tn % Row Count 8 (+ 1) % Row 7 \SetRowColor{white} cl:(n|b|l|r) & `clear: none|both|left|right;` \tn % Row Count 10 (+ 2) % Row 8 \SetRowColor{LightBackground} \seqsplit{d:(n|b|f|i|ib)} & `display: \seqsplit{none|block|flex|inline|inline-block;`} \tn % Row Count 12 (+ 2) % Row 9 \SetRowColor{white} v:(v|h) & `visibility: visible|hidden;` \tn % Row Count 14 (+ 2) % Row 10 \SetRowColor{LightBackground} ov:(v|h|s) & `overflow: visible|hidden|scroll;` \tn % Row Count 16 (+ 2) % Row 11 \SetRowColor{white} ovx:() & `overflow-x: visible|hidden|scroll;` \tn % Row Count 18 (+ 2) % Row 12 \SetRowColor{LightBackground} ovy:() & `overflow-y: visible|hidden|scroll;` \tn % Row Count 20 (+ 2) % Row 13 \SetRowColor{white} m & `margin` \tn % Row Count 21 (+ 1) % Row 14 \SetRowColor{LightBackground} m(r|t|b|l) & \seqsplit{`margin-right|top|bottom|left;`} \tn % Row Count 23 (+ 2) % Row 15 \SetRowColor{white} p & `padding` \tn % Row Count 24 (+ 1) % Row 16 \SetRowColor{LightBackground} p(t|r|b|l) & \seqsplit{`padding-top|right|bottom|left;`} \tn % Row Count 26 (+ 2) % Row 17 \SetRowColor{white} bxz:bb & `box-sizing: border-box;` \tn % Row Count 27 (+ 1) % Row 18 \SetRowColor{LightBackground} w & `width` \tn % Row Count 28 (+ 1) % Row 19 \SetRowColor{white} h & `height` \tn % Row Count 29 (+ 1) % Row 20 \SetRowColor{LightBackground} maw & `max-width` \tn % Row Count 30 (+ 1) \end{tabularx} \par\addvspace{1.3em} \vfill \columnbreak \begin{tabularx}{8.4cm}{x{2.8 cm} x{5.2 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{CSS (cont)}} \tn % Row 21 \SetRowColor{LightBackground} mah & `max-height` \tn % Row Count 1 (+ 1) % Row 22 \SetRowColor{white} miw & `min-width` \tn % Row Count 2 (+ 1) % Row 23 \SetRowColor{LightBackground} mih & `min-height` \tn % Row Count 3 (+ 1) % Row 24 \SetRowColor{white} fw & `font-weight` \tn % Row Count 4 (+ 1) % Row 25 \SetRowColor{LightBackground} fz & `font-size` \tn % Row Count 5 (+ 1) % Row 26 \SetRowColor{white} ff & `font-family` \tn % Row Count 6 (+ 1) % Row 27 \SetRowColor{LightBackground} ta:(l|c|r|j) & `text-align: \seqsplit{left|center|right|justify;`} \tn % Row Count 8 (+ 2) % Row 28 \SetRowColor{white} td:n & `text-decoration: none;` \tn % Row Count 9 (+ 1) % Row 29 \SetRowColor{LightBackground} lh & `line-height` \tn % Row Count 10 (+ 1) % Row 30 \SetRowColor{white} bg:n & `background: none` \tn % Row Count 11 (+ 1) % Row 31 \SetRowColor{LightBackground} bg+ & `background: \#fff url() 0 0 no-repeat;` \tn % Row Count 13 (+ 2) % Row 32 \SetRowColor{white} c:(r|ra) & `color: rgb()|rgba();` \tn % Row Count 14 (+ 1) % Row 33 \SetRowColor{LightBackground} op & `opacity` \tn % Row Count 15 (+ 1) % Row 34 \SetRowColor{white} cnt & `content:'';` \tn % Row Count 16 (+ 1) % Row 35 \SetRowColor{LightBackground} ol:n & `outline: none;` \tn % Row Count 17 (+ 1) % Row 36 \SetRowColor{white} bd+ & `border: 1px solid \#000;` \tn % Row Count 18 (+ 1) % Row 37 \SetRowColor{LightBackground} bd:n & `border: none;` \tn % Row Count 19 (+ 1) % Row 38 \SetRowColor{white} bd(t|r|l|b)+ & \seqsplit{`border-top|right|left|bottom:} 1px solid \#000;` \tn % Row Count 21 (+ 2) % Row 39 \SetRowColor{LightBackground} bdrs & `border-radius` \tn % Row Count 22 (+ 1) % Row 40 \SetRowColor{white} lis:n & `list-style: none;` \tn % Row Count 23 (+ 1) % Row 41 \SetRowColor{LightBackground} ! & `!important` \tn % Row Count 24 (+ 1) % Row 42 \SetRowColor{white} @f & `font-face` \tn % Row Count 25 (+ 1) % Row 43 \SetRowColor{LightBackground} @kf & `keyframes` \tn % Row Count 26 (+ 1) % Row 44 \SetRowColor{white} @m & `media` \tn % Row Count 27 (+ 1) % Row 45 \SetRowColor{LightBackground} anim- & `animation` \tn % Row Count 28 (+ 1) % Row 46 \SetRowColor{white} \seqsplit{ai:(b|c|fe|fs|s|sa|sb)} & `align-items: \seqsplit{baseline|center|flex-end|flex-start|stretch|space-around|space-between;`} \tn % Row Count 32 (+ 4) \end{tabularx} \par\addvspace{1.3em} \vfill \columnbreak \begin{tabularx}{8.4cm}{x{2.8 cm} x{5.2 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{8.4cm}}{\bf\textcolor{white}{CSS (cont)}} \tn % Row 47 \SetRowColor{LightBackground} fxd:(c|r) & `flex-direction: column|row;` \tn % Row Count 2 (+ 2) % Row 48 \SetRowColor{white} \seqsplit{jc:(c|fe|fs|sa|sb)} & `justify-content: \seqsplit{baseline|flex-end|flex-start|space-around|space-between;`} \tn % Row Count 5 (+ 3) % Row 49 \SetRowColor{LightBackground} \seqsplit{trf:(r|sc|skx|sky|t)} & `transform: \seqsplit{rotate|scale|skewX|skewY|translate;`} \tn % Row Count 7 (+ 2) % Row 50 \SetRowColor{white} trs & `transition` \tn % Row Count 8 (+ 1) % Row 51 \SetRowColor{LightBackground} trfo & `transform-origin` \tn % Row Count 9 (+ 1) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} % That's all folks \end{multicols*} \end{document}