DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> HTML基礎知識 >> HTML和Xhtml >> 使用HTML編寫簡單的郵件模版
使用HTML編寫簡單的郵件模版
編輯:HTML和Xhtml     

今天,我想寫一個"低技術"問題。

  話說我訂閱了不少了新聞郵件(Newsletter),比如JavaScript Weekly。每周收到一封郵件,了解本周的大事。
2015712153636746.jpg (349×460)

 有一天,我就在想,是不是我也能做一個這樣的郵件?

  然後,就發現這事不那麼容易。拋開後台和編輯工作,單單是設計一個Email樣板,就需要不少心思。
2015712153840405.jpg (550×671)

因為這種帶格式的郵件,其實就是一張網頁,正式名稱叫做HTML Email。它能否正常顯示,完全取決於郵件客戶端。大多數的郵件客戶端(比如Outlook和Gmail),會過濾HTML設置,讓郵件面目全非。

  我發現,編寫HTML Email的竅門,就是使用15年前的網頁制作方法。下面就是我整理的編寫指南。

  1. Doctype

  目前,兼容性最好的Doctype是XHTML 1.0 Strict,事實上Gmail和Hotmail會刪掉你的Doctype,換上這個Doctype。

XML/HTML Code復制內容到剪貼板
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2.   
  3. <html xmlns="http://www.w3.org/1999/xhtml">  
  4.   
  5.  <head>  
  6.   
  7.   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />  
  8.   
  9.   <title>HTML Email編寫指南</title>  
  10.   
  11.   <meta name="viewport" content="width=device-width, initial-scale=1.0"/>  
  12.   
  13.  </head>  
  14.   
  15. </html>  

  使用這個Doctype,也就意味著,不能使用HTML5的語法。

  2. 布局

  網頁的布局(layout)必須使用表格(table)。首先,放置一個最外層的大表格,用來設置背景。

XML/HTML Code復制內容到剪貼板
  1. <body style="margin: 0; padding: 0;">  
  2.   
  3.  <table border="1" cellpadding="0" cellspacing="0" width="100%">  
  4.   
  5.   <tr>  
  6.    <td> Hello! </td>  
  7.   </tr>  
  8.   
  9.  </table>  
  10.   
  11. </body>  

  表格的 border 屬性等於1, 是為了方便開發。正式發布的時候,再把這個屬性設為0。

  在內層,放置第二個表格。用來展示內容。第二個table的寬度定為600像素,防止超過客戶端的顯示寬度。

XML/HTML Code復制內容到剪貼板
  1. <table align="center" border="1" cellpadding="0" cellspacing="0" width="600" style="border-collapse: collapse;">  
  2.   
  3.  <tr>  
  4.   <td> Row 1 </td>  
  5.  </tr>  
  6.   
  7.  <tr>  
  8.   <td> Row 2 </td>  
  9.  </tr>  
  10.   
  11.  <tr>  
  12.   <td> Row 3 </td>  
  13.  </tr>  
  14.   
  15. </table>  

  郵件內容有幾個部分,就設置幾行(row)。

  3. 圖片

  圖片是唯一可以引用的外部資源。其他的外部資源,比如樣式表文件、字體文件、視頻文件等,一概不能引用。

  有些客戶端會給圖片鏈接加上邊框,要去除邊框。

CSS Code復制內容到剪貼板
  1.   img {outline:none; text-decoration:none; -ms-interpolation-mode: bicubic;}   
  2.   
  3.   a img {border:none;}   
  4.   
  5.   <img border="0" style="display:block;">  

  需要注意的是,不少客戶端默認不顯示圖片(比如Gmail),所以要確保即使沒有圖片,主要內容也能被閱讀。

  4. 行內樣式

  所有的CSS規則,最好都采用行內樣式。因為放置在網頁頭部的樣式,很可能會被客戶端刪除。客戶端對CSS規則的支持情況,請看這裡。

  另外,不要采用CSS的簡寫形式,有些客戶端不支持。比如,不要寫成下面這樣:

      

XML/HTML Code復制內容到剪貼板
  1. style="font: 8px/14px Arial, sans-serif;"  

  如果想表達

     

XML/HTML Code復制內容到剪貼板
  1.  <p style="margin: 1em 0;">  

  要寫成下面這樣:

      

XML/HTML Code復制內容到剪貼板
  1. <p style="margin-top: 1em; margin-bottom: 1em; margin-left: 0; margin-right: 0;">  

  5. W3C校驗和測試工具

  要保證最終的代碼,能夠通過W3C的校驗,因為某些客戶端會把不合格屬性剝離。還要使用測試工具(1, 2, 3),查看在不同客戶端的顯示結果。

  發送HTML Email的時候,不要忘記MIME類型不能使用

     

XML/HTML Code復制內容到剪貼板
  1.  Content-Type: text/plain;  

  而要使用

      

XML/HTML Code復制內容到剪貼板
  1. Content-Type: Multipart/Alternative;  

  發送工具可以考慮使用 MailChimp 和 Campaign Monitor 。

  6. 模板

  使用別人已經做好的模板,是一個不錯的選擇(這裡和這裡),網上還可以搜到更多。

  自己開發的話,可以參考HTML Email Boilerplate和Emailology。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved