作者:? 阮一峰
?
今天,我想寫一個(gè)"低技術(shù)"問(wèn)題。
?
話說(shuō)我訂閱了不少了新聞郵件(Newsletter),比如 JavaScript Weekly 。每周收到一封郵件,了解本周的大事。
?
?
有一天,我就在想,是不是我也能做一個(gè)這樣的郵件?
然后,就發(fā)現(xiàn)這事不那么容易。拋開(kāi)后臺(tái)和編輯工作,單單是設(shè)計(jì)一個(gè)Email樣板,就需要不少心思。
?
因?yàn)檫@種帶格式的郵件,其實(shí)就是一張網(wǎng)頁(yè),正式名稱叫做 HTML Email 。它能否正常顯示,完全取決于郵件客戶端。大多數(shù)的郵件客戶端(比如Outlook和Gmail),會(huì)過(guò)濾HTML設(shè)置,讓郵件面目全非。
?
我發(fā)現(xiàn),編寫HTML Email的竅門,就是使用15年前的網(wǎng)頁(yè)制作方法。下面就是我整理的編寫指南。
?
1. Doctype
目前,兼容性最好的Doctype是XHTML 1.0 Strict,事實(shí)上Gmail和Hotmail會(huì)刪掉你的Doctype,換上這個(gè)Doctype。
<!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>
使用這個(gè)Doctype,也就意味著,不能使用HTML5的語(yǔ)法。
?
2. 布局
網(wǎng)頁(yè)的布局(layout)必須使用表格(table)。首先,放置一個(gè)最外層的大表格,用來(lái)設(shè)置背景。
<body style="margin: 0; padding: 0;"> <table border="1" cellpadding="0" cellspacing="0" width="100%"> <tr> <td> Hello! </td> </tr> </table> </body>
表格的 border 屬性等于1, 是為了方便開(kāi)發(fā)。正式發(fā)布的時(shí)候,再把這個(gè)屬性設(shè)為0。
?
在內(nèi)層,放置第二個(gè)表格。用來(lái)展示內(nèi)容。第二個(gè)table的寬度定為600像素,防止超過(guò)客戶端的顯示寬度。
<table align="center" border="1" cellpadding="0" cellspacing="0" width="600" style="border-collapse: collapse;"> <tr> <td> Row 1 </td> </tr> <tr> <td> Row 2 </td> </tr> <tr> <td> Row 3 </td> </tr> </table>
郵件內(nèi)容有幾個(gè)部分,就設(shè)置幾行(row)。
?
3. 圖片
圖片是唯一可以引用的外部資源。其他的外部資源,比如樣式表文件、字體文件、視頻文件等,一概不能引用。
?
有些客戶端會(huì)給圖片鏈接加上邊框,要去除邊框。
img {outline:none; text-decoration:none; -ms-interpolation-mode: bicubic;} a img {border:none;} <img border="0" style="display:block;">
需要注意的是,不少客戶端默認(rèn)不顯示圖片(比如Gmail),所以要確保即使沒(méi)有圖片,主要內(nèi)容也能被閱讀。
?
4. 行內(nèi)樣式
所有的CSS規(guī)則,最好都采用行內(nèi)樣式。因?yàn)榉胖迷诰W(wǎng)頁(yè)頭部的樣式,很可能會(huì)被客戶端刪除。客戶端對(duì)CSS規(guī)則的支持情況,請(qǐng)看 這里 。
?
另外,不要采用CSS的簡(jiǎn)寫形式,有些客戶端不支持。比如,不要寫成下面這樣:
style="font: 8px/14px Arial, sans-serif;"
?
如果想表達(dá)
<p style="margin: 1em 0;">
?
要寫成下面這樣:
<p style="margin-top: 1em; margin-bottom: 1em; margin-left: 0; margin-right: 0;">
?
5. W3C校驗(yàn)和測(cè)試工具
?
要保證最終的代碼,能夠通過(guò) W3C 的校驗(yàn),因?yàn)槟承┛蛻舳藭?huì)把不合格屬性剝離。還要使用測(cè)試工具( 1 ,? 2 ,? 3 ),查看在不同客戶端的顯示結(jié)果。
?
發(fā)送HTML Email的時(shí)候,不要忘記MIME類型不能使用
Content-Type: text/plain;
?
而要使用
Content-Type: Multipart/Alternative;
?
發(fā)送工具可以考慮使用? MailChimp ?和? Campaign Monitor ?。
?
6. 模板
使用別人已經(jīng)做好的模板,是一個(gè)不錯(cuò)的選擇( 這里 和 這里 ),網(wǎng)上還可以搜到 更多 。
自己開(kāi)發(fā)的話,可以參考 HTML Email Boilerplate 和 Emailology 。
?
7. 參考鏈接
進(jìn)一步研究,請(qǐng)參考下面的文章。
?
- Sean Powell,
Say Hello to the HTML Email Boilerplate
- Nicole Merlin,
Build an HTML Email Template From Scratch
- Nicole Merlin,?
What You Should Know About HTML Email
?
?
via :? http://www.ruanyifeng.com/blog/2013/06/html_email.html ?
?
轉(zhuǎn)自地址: http://linux.cn/article-2939-1.html
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
