做網頁設計的朋友都可能有這樣的感覺,用寫HTML頁面的方式寫email是災難,在各種email client顯示各種走樣,所以要寫好html Email要先了解基本的語法,下面介紹一下:
帶格式的郵件,本質上是一張網頁,正式名稱叫做HTML Email。它能否正常顯示,完全取決於郵件客戶端。大多數的郵件客戶端(比如Outlook和Gmail),會過濾HTML設置,讓郵件面目全非。
編寫HTML Email的竅門,就是使用古老的網頁製作方法。
Doctype
目前,兼容性最好的Doctype是XHTML 1.0 Strict,事實上Gmail和Hotmail會刪掉你的Doctype,換上這個Doctype。
使用這個Doctype,也就意味著,不能使用HTML5的語法。
佈局
HTML email網頁的佈局(layout)必須使用表格(table)。首先,放置一個最外層的大表格,用來設置背景。
<body style="margin: 0; padding: 0;">
<table border="1" cellpadding="0" cellspacing="0" width="100%">
<tr>
<td> Hello Email! </td>
</tr>
</table>
</body>
表格的 border 屬性等於1, 是為了方便開發。正式發佈的時候,再把這個屬性設為0。
在內層,放置第二個表格。用來展示內容。第二個table的寬度定為600像素,防止超過客戶端的顯示寬度。
郵件內容有幾個部分,就設置幾行(row)。
<table align="center" border="1" cellpadding="0" cellspacing="0" width="620" style="border-collapse: collapse;">
<tr>
<td> 第一行 1 </td>
</tr>
<tr>
<td> 第二行 2 </td>
</tr>
<tr>
<td> 第三行 3 </td>
</tr>
</table>
圖片
圖片是唯一可以引用的外部資源。其他的外部資源,比如樣式表文件、字體文件、視頻文件等,一概不能引用。
有些客戶端會給圖片鏈接加上邊框,要去除邊框。
img {outline:none; text-decoration:none; -ms-interpolation-mode: bicubic;}
a img {border:none;}
<img border="0" style="display:block;">
需要注意的是,不少客戶端默認不顯示圖片(比如Gmail),所以要確保即使沒有圖片,主要內容也能被閱讀。
行內樣式(Inline CSS)
所有的CSS規則,最好都採用行內樣式。因為放置在網頁頭部的樣式,很可能會被客戶端刪除。客戶端對CSS規則的支持情況。
另外,不要採用CSS的簡寫形式,有些客戶端不支持。比如,不要寫成下面這樣:
style="font: 8px/14px Arial, sans-serif;"
如果想表達
<p style="margin: 1em 0;">
要寫成下面這樣:
<p style="margin-top: 1em; margin-bottom: 1em; margin-left: 0; margin-right: 0;">
W3C校驗和測試工具
要保證最終的代碼,能夠通過W3C的校驗,因為某些客戶端會把不合格屬性剝離。還要使用測試工具(1, 2, 3),查看在不同客戶端的顯示結果。
發送HTML Email的時候,不要忘記MIME類型不能使用
Content-Type: text/plain;
而要使用
Content-Type: Multipart/Alternative;
上面說了很多要求,下面給個實際的例子參考
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>HTML Email語法技巧</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
</html>