Email HTML
The basics
HTML (HyperText Markup Language) is markup language for documents that are meant to be displayed in a web browser. HTML sends an information to a web browser how specific elements of a web page are displayed on a computer screen. The information in conveyed, through HTML tags, attributes, and values.
HTML can also be used to stylise emails that are sent the same way a web page is stylised. There are some limitations to what tags and attributes can be used in an email.
HTML tag structure
HTML tags follow basic structure:
opening tag:
<tag>
closing tag:
</tag>
example:
<tag>content</tag>
.
Tags can have added attributes to them like this:
<tag attribute="value">content</tag>
,
example:
<a href="https://contract-signatures.com">this is a link</a>
.
Some tags may more than one attribute, for example:
<img src="pictures/image.png" alt="example image" />
.
Learn more about tags and their attributes here
Limitations
In order to maintain a safe environment and protect against potential vulnerabilities such as cross-site scripting (XSS) attacks or the risk of being flagged for sending spam-like or malicious content, we have implemented a whitelist system for HTML elements.
This means that only specific HTML tags are allowed within our communication framework. These tags have been carefully selected to ensure both the security of our platform and the reliability of our messages.
As previously mentioned, for safety reasons, there are limitations to how emails can be formatted.
The limitations are listed below:
Width should be restricted to 600px.
Background image is not allowed.
CSS is not allowed.
It is recommended to use table layout.
Allowed HTML tags:
<a>
, <b>
, <blockquote>
, <br>
, <caption>
, <cite>
, <code>
, <col>
, <colgroup>
, <dd>
, <div>
, <dl>
, <dt>
, <em>
, <h1>
to <h6>
, <i>
, <img>
, <li>
, <ol>
, <p>
, <pre>
, <q>
, <small>
, <span>
, <strike>
, <strong>
, <sub>
, <sup>
, <table>
, <tbody>
, <td>
, <tfoot>
, <th>
, <thead>
, <tr>
, <u>
, <ul>
,
Attributes allowed for a tag:
HTML tag |
Allowed attributes |
---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Protocols allowed for specific attributes:
HTML Tag/Attribute |
Allowed protocols |
---|---|
|
ftp, http, https, mailto |
|
http, https |
|
http, https |
|
http, https |
|
http, https |
Email formatting
Text styling
Use tags below to style text in a certain way:
Tag effect |
Tag usage |
---|---|
bold text |
|
important text |
|
italic text |
|
emphasized text |
A screen reader will pronounce the words in |
|
|
superscripttext |
|
subscripttext |
|
small text |
|
h1 text |
|
h2 text |
|
h3 text |
|
h4 text |
|
h5 text |
|
h6 text |
|
cited text |
The |
“quoted text” |
|
attribute |
|
|
|
Text formatting
Text paragraph
The <p>
tag defines paragraph, web browsers automatically add a single blank line before and after
each <p>
element.
<p>
This example text
contains few lines
in the source code,
but the browser displays it
as a singe line.
</p>
Remember when using paragraph tag, the way text is formatted in source code may differ from text displayed in an email.
Will be displayed as:
This example text contains few lines in the source code, but the browser displays it as a single line.
Line break
The <br>
tag inserts a single line break, it is useful to split text in a controlled manner.
<p>
This example paragraph <br>
contains few lines of text <br>
in the source code, <br>
this time, line break was used <br>
so it displays in separate lines.
</p>
Will be displayed as:
This example paragraph
contains few lines of text
in the source code,
this time, line break was used
so it displays in separate lines.
Preformatted text
Text in a <pre>
element is displayed in a fixed-width font. The text preserves both spaces and line breaks. The text will be displayed exactly as written in the HTML source code.
<p>
<pre>
This example text
contains few lines
in the source code,
but the browser displays it
as a singe line.
</pre>
</p>
Will be displayed as:
This example text
contains few lines
in the source code,
but the browser displays it
as a single line.
Quoted section
The <blockquote>
tag specifies a section that is quoted from another source. Browsers usually indent <blockquote>
elements. The cite
attribute specifies the source of the quotation.
<p>This is just a paragraph</p>
<blockquote cite="https://www.w3.org/History/1989/proposal.html">
This proposal concerns the management of general information about <br>
accelerators and experiments at CERN.
It discusses the problems of loss of information <br>
about complex evolving systems and derives a solution based on
a distributed hypertext system.
</blockquote>
This is text written without using any tags
Will be displayed as:
This is just a paragraph
This proposal concerns the management of general information about
accelerators and experiments at CERN. It discusses the problems of loss of information
about complex evolving systems and derives a solution based on a distributed hypertext system.
This is text written without using any tags
Lists:
Ordered list:
Item number 1
Item number 2
Item number 3
Numbered List:
Item number 1
Item number 2
Item number 3
Lists HTML representation:
<p>Ordered list:</p>
<ol>
<li>Item number 1</li>
<li>Item number 2</li>
<li>Item number 3</li>
</ol>
<p>Numbered List:</p>
<ul>
<li>Item number 1</li>
<li>Item number 2</li>
<li>Item number 3</li>
</ul>
Description list:
Orange
Round orange fruit
Cucumber
Long oblong green vegetable
Description list HTML representation:
<dl>
<dt>Orange</dt>
<dd>Round orange fruit</dd>
<dt>Cucumber</dt>
<dd>Long oblong green vegetable/dd>
</dl>
Images
Some email clients disable displaying images by default. If email is mainly composed out of images, these clients will turn them into a lot of empty space with occasional text.
To avoid any loss of information, it is recommended, to use images only as decoration.
If an image is used as a button, it may cause problems to the email receiver, especially if the button is a link or directs to an important page.
Images blocked by an email client
Images allowed by an email client
Another significant thing when adding an image is to provide an alt
text. This will help avoid confusion if the image is blocked or not properly displayed. Here are some things to consider while adding the alt
text:
all images should include the
alt
attributealternative text should inform about the content and function of an image
alternative text should not be redundant
alternative text depends on the context provided by the content surrounding an image
decorative images should use an empty
alt
attribute
Email structure
Tables can be used as an addition to an email or as a main structure where all the content regarding receiver, text, links etc. will be placed. Table structure is quite simple, yet sometimes confusing, especially when it comes to merging cells. Here is a resource that will help create tables: table creator.
Below simple example of 3 by 3 table with head row.
Table:
Title 1 |
Title 2 |
Title 3 |
---|---|---|
abc |
xyz |
jkl |
mno |
opr |
uwx |
Table HTML representation:
<table>
<thead>
<tr>
<th>Title 1</th>
<th>Title 2</th>
<th>Title 3</th>
</tr>
</thead>
<tbody>
<tr>
<td>abc</td>
<td>xyz</td>
<td>jkl</td>
</tr>
<tr>
<td>mno</td>
<td>opr</td>
<td>uwx</td>
</tr>
</tbody>
</table>
Email structure – source code
Tags such as div
and/or span
may help tidy up readability of source code of an email. They act as divisions or section in HTML. These tags can contain any type of content, and are a useful tool to make navigation of a source code easier and faster.
The <span>
tag is much like the <div>
element, but <div>
is a block-level element and <span>
is an inline element.
<div>
<h2>This is title of a first section</h2>
<p>This is some text in a div element.</p>
<a href="#">This is link included in a div</a>
</div>
<div>
<h2>This is title of a second section</h2>
<p>
This is some text in a div element. <br>
Second line of some text.
</p>
<span><h4>This is an important link:</h4><b><a href="#">important link</a></b>
</div>
By default, browsers always place a line break before and after the <div>
element.
Default email template
Default email look is a result of testing readability and deliverability to different email service providers.
It may sound like a simple task, but there are lots of things to consider, especially with the amount of available email clients.
The goal was to make email simple yet full comprehensive. All the most important information were compressed into this template.