\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{HaffouzMohamedAmin} \pdfinfo{ /Title (html.pdf) /Creator (Cheatography) /Author (HaffouzMohamedAmin) /Subject (HTML 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}{F06529} \definecolor{LightBackground}{HTML}{FEF5F1} \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{HTML Cheat Sheet}}}} \\ \normalsize{by \textcolor{DarkBackground}{HaffouzMohamedAmin} via \textcolor{DarkBackground}{\uline{cheatography.com/210366/cs/45586/}}} \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}HaffouzMohamedAmin \\ \uline{cheatography.com/haffouzmohamedamin} \\ \end{tabulary} \vfill \columnbreak \begin{tabulary}{5.8cm}{L} \SetRowColor{FootBackground} \mymulticolumn{1}{p{5.377cm}}{\bf\textcolor{white}{Cheat Sheet}} \\ \vspace{-2pt}Published 5th February, 2025.\\ Updated 4th February, 2025.\\ 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{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Structure générale}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\textless{}!DOCTYPE html\textgreater{} \newline \textless{}html lang="en"\textgreater{} \newline \textless{}head\textgreater{} \newline \textless{}!-{}-ici l'en-tête du document-{}-\textgreater{} \newline \textless{}/head\textgreater{} \newline \textless{}body\textgreater{} \newline \textless{}!-{}-corps du document-{}-\textgreater{} \newline \textless{}/body\textgreater{} \newline \textless{}/html\textgreater{}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{\textless{}head\textgreater{} content}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{{\emph{titre pour la page :}}} \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}title\textgreater{}Mon Site Web\textless{}/title\textgreater{}`} \tn % Row Count 2 (+ 1) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{{\emph{pour les données méta :}}} \tn % Row Count 3 (+ 1) % Row 3 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}meta name="......." content=".........."\textgreater{}`} \tn % Row Count 4 (+ 1) \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{4.3175 cm} x{12.9525 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{17.67cm}}{\bf\textcolor{white}{Exemples de métadata}} \tn % Row 0 \SetRowColor{LightBackground} {\bf{name}} & {\bf{content}} \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} `author` & ton nom \tn % Row Count 2 (+ 1) % Row 2 \SetRowColor{LightBackground} \seqsplit{`keywords`} & Mots-clés qui , si saisit dans le moteur de recherche, conduisent à ton site \tn % Row Count 5 (+ 3) % Row 3 \SetRowColor{white} \seqsplit{`category`} & catégorie du site \tn % Row Count 6 (+ 1) % Row 4 \SetRowColor{LightBackground} \seqsplit{`language`} & `"fr"`,`"en"`,`"de"`,`"es"`,... \tn % Row Count 8 (+ 2) % Row 5 \SetRowColor{white} \seqsplit{`description`} & A short description for the website \tn % Row Count 10 (+ 2) % Row 6 \SetRowColor{LightBackground} \seqsplit{`copyright`} & Les copyrights du site \tn % Row Count 12 (+ 2) % Row 7 \SetRowColor{white} \seqsplit{`generator`} & les différents logiciels utilisés \tn % Row Count 14 (+ 2) % Row 8 \SetRowColor{LightBackground} `date` & Date de création du site \tn % Row Count 15 (+ 1) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{metadata http-equiv}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{{\bf{used to modify the aspect of the website and his interactions with the browser}}} \tn % Row Count 2 (+ 2) % Row 1 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{{\emph{to specify the UTF-8 encoding for caracters :}}} \tn % Row Count 3 (+ 1) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}meta \seqsplit{http-equiv="Content-Type"} content="text/html; charset=UTF-8"\textgreater{}`} \tn % Row Count 5 (+ 2) % Row 3 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{{\emph{autorefresh :}}} \tn % Row Count 6 (+ 1) % Row 4 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}meta http-equiv="refresh" content="30"\textgreater{}`} \tn % Row Count 7 (+ 1) \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{x{6.0445 cm} x{11.2255 cm} } \SetRowColor{DarkBackground} \mymulticolumn{2}{x{17.67cm}}{\bf\textcolor{white}{body tags}} \tn % Row 0 \SetRowColor{LightBackground} paragraphe & `\textless{}p\textgreater{}...\textless{}/p\textgreater{}` \tn % Row Count 1 (+ 1) % Row 1 \SetRowColor{white} retour à la ligne & `\textless{}br/\textgreater{}` \tn % Row Count 3 (+ 2) % Row 2 \SetRowColor{LightBackground} headers & `\textless{}h1\textgreater{}...\textless{}/h1\textgreater{}` (1 -\textgreater{} 5) \tn % Row Count 4 (+ 1) % Row 3 \SetRowColor{white} image & `\textless{}img src="...." alt="alt text"\textgreater{}` \tn % Row Count 6 (+ 2) % Row 4 \SetRowColor{LightBackground} lien & `\textless{}a href="link"\textgreater{}....\textless{}/a\textgreater{}` \tn % Row Count 7 (+ 1) % Row 5 \SetRowColor{white} link for mails & `\textless{}a href="mailto:...@.."\textgreater{}....\textless{}/a\textgreater{}` \tn % Row Count 9 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}--} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Unordered lists}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\textless{}ul\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}/ul\textgreater{}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Ordered lists}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\textless{}ol\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}li\textgreater{}....\textless{}/li\textgreater{} \newline \textless{}/ol\textgreater{}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Definition list}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\textless{}dl\textgreater{} \newline \textless{}dt\textgreater{}def title\textless{}/dt\textgreater{} \newline \textless{}dd\textgreater{}def paragraph\textless{}/dd\textgreater{} \newline \newline \textless{}dt\textgreater{}def title\textless{}/dt\textgreater{} \newline \textless{}dd\textgreater{}def paragraph\textless{}/dd\textgreater{} \newline \textless{}/dl\textgreater{}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Table Layout}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{\textless{}table\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td rowspan=2\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}tr\textgreater{}\textless{}td\textgreater{}1\textless{}/td\textgreater{}\textless{}td\textgreater{}2\textless{}/td\textgreater{}\textless{}td\textgreater{}3\textless{}/td\textgreater{}\textless{}/tr\textgreater{} \newline \textless{}/table\textgreater{}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{.}} \tn \SetRowColor{LightBackground} \mymulticolumn{1}{p{17.67cm}}{\vspace{1px}\centerline{\includegraphics[width=5.1cm]{/web/www.cheatography.com/public/uploads/haffouzmohamedamin_1738650300_Screenshot from 2025-02-04 05-17-27.png}}} \tn \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \begin{tabularx}{17.67cm}{X} \SetRowColor{DarkBackground} \mymulticolumn{1}{x{17.67cm}}{\bf\textcolor{white}{Forms}} \tn % Row 0 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}form \seqsplit{action="url\_to\_handle\_form\_data"} method="GET or POST" name="form name"\textgreater{}\textless{}!-{}-form body-{}-\textgreater{}\textless{}/form\textgreater{}`} \tn % Row Count 3 (+ 3) % Row 1 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{{\emph{a good practise of forms content is to put a name for each input}}} \tn % Row Count 5 (+ 2) % Row 2 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}label for="input\_name"\textgreater{}text\textless{}/label\textgreater{}` Labels} \tn % Row Count 6 (+ 1) % Row 3 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="text"/\textgreater{}` a text field input} \tn % Row Count 7 (+ 1) % Row 4 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="password"/\textgreater{}` a password input} \tn % Row Count 8 (+ 1) % Row 5 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="number"/\textgreater{}` a phone number input} \tn % Row Count 9 (+ 1) % Row 6 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type"date"/\textgreater{}` date input} \tn % Row Count 10 (+ 1) % Row 7 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="time"/\textgreater{}` time input} \tn % Row Count 11 (+ 1) % Row 8 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type"datetime"/\textgreater{}` datetime input} \tn % Row Count 12 (+ 1) % Row 9 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="range"/\textgreater{}` inputs a float using a slider} \tn % Row Count 14 (+ 2) % Row 10 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="checkbox" name="input\_name"\textgreater{}` for multiple selection} \tn % Row Count 16 (+ 2) % Row 11 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="radio"\textgreater{}` for single selection} \tn % Row Count 17 (+ 1) % Row 12 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="file"\textgreater{}` for file upload} \tn % Row Count 18 (+ 1) % Row 13 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="submit"\textgreater{}` for a submit button} \tn % Row Count 19 (+ 1) % Row 14 \SetRowColor{LightBackground} \mymulticolumn{1}{x{17.67cm}}{`\textless{}input type="reset"\textgreater{}` for a form reset button} \tn % Row Count 20 (+ 1) % Row 15 \SetRowColor{white} \mymulticolumn{1}{x{17.67cm}}{`\textless{}select name="...."\textgreater{}\textless{}option value="backend\_value"\textgreater{}option name\textless{}/option\textgreater{}  ...\textless{}/select\textgreater{}`} \tn % Row Count 22 (+ 2) \hhline{>{\arrayrulecolor{DarkBackground}}-} \end{tabularx} \par\addvspace{1.3em} \end{document}