响应式电子邮件无法在iPhone上运行

时间:2014-02-05 21:45:46

标签: css iphone responsive-design html-email

我是响应式设计的新手,所以我提前道歉。我正在收集当前的电子邮件,并使其中的一部分响应。我有一个3列的电子邮件,并希望它堆叠到一列,并使文本更大。我通过浏览器获得了成功的结果,但是一旦我在iPhone 5上查看它,我什么也得不到。我已发送到AOL,Gmail和Outlook帐户,但没有人对这一列做出反应。我在下面列出了我的风格。再说一遍,我对整个媒体查询都不熟悉,所以如果它看起来很荒谬我会道歉。

<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">

 <style type="text/css">
    @media only screen and (max-width: 660px) {
    table.container {width: 100% !important; padding:0 4px;}    
            table.container {
        text-align: center !important;
        font-size:20px !important;
    }   

    .templateColumnContainer{
        display:block !important;
        width:100% !important;
    }
}

@media only screen and (max-width: 568px) {

    table.container {width: 100% !important; padding:0 4px;}    
    table.container {
        text-align: center !important;
        font-size:20px !important;  
    }

    .templateColumnContainer {
        display:block !important;
        width:100% !important;
    }
}
  @media only screen and (max-width: 480px) {

    table.container {width: 100% !important; padding:0 4px;}    
    table.container {
        text-align: center !important;
        font-size:20px !important;  
    }

    .templateColumnContainer {
        display:block !important;
        width:100% !important;
    }
}

@media only screen and (max-width: 320px) {

    table.container {width: 280px !important; padding:0 4px;}   
    table.container {
        text-align: center !important;
        font-size:20px !important;  
    }

    .templateColumnContainer {
        display:block !important;
        width:100% !important;
    }
}


            </style>
        </head>

4 个答案:

答案 0 :(得分:0)

Gmail,AOL和Outlook.com所有do not support媒体查询。尝试将其发送到iPhone上的默认邮件阅读器。

答案 1 :(得分:0)

改为流体设计是明智的。 1.创建100%宽度的包装表。 2.嵌套宽度为100%的容器表。​​但是有一个表格单元格,其宽度和最大宽度保持邮件设计宽度。一定要在此TD上放置一个align = center。

在此容器表中,您可以开始构建邮件。使用align属性创建在视口更改后移动的元素。

您实际上可以对某些移动设备使用媒体查询。放入头部,您可以根据视口更改使用媒体查询。

答案 2 :(得分:0)

让您的电子邮件快速响应的最佳方式: 添加元数:

<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" />
<meta name="x-apple-disable-message-reformatting" />

如果你需要用于outlook的sans-serif字体,请将其作为头部和头部:

<!--[if mso]>
<style type="text/css">
    h1, h2, h3, h4, h5, h6, p, a, span, td, em, strong {
        font-family: Helvetica, Arial, sans-serif;
    }
</style>
<![endif]-->

制作基于表格的设计。

<table width="100%" cellspacing="0" cellpadding="0" border="0" align="center" style="border-collapse: collapse;mso-table-lspace: 0pt;mso-table-rspace: 0pt;-ms-text-size-adjust: 100%;-webkit-text-size-adjust: 100%;margin: 0;padding: 0;margin:0 auto;">
<tbody>
<tr>
    <td valign="middle" align="center">
        <table class="fullwidth" width="600" cellspacing="0" cellpadding="0" border="0" align="center" style="borde-r-collapse: collapse;mso-table-lspace: 0pt;mso-table-rspace: 0pt;-ms-text-size-adjust: 100%;-webkit-text-size-adjust: 100%;margin: 0;padding: 0;margin:0 auto;">
            <tbody>
            <tr>
                <td style="font-size:5px;line-height:5px; height: 10px">&nbsp;</td> <!-- paddign & margin not supported by Outlook -->
            </tr>
            <tr>
                <td valign="middle" align="center">
                    <!-- Add fun here -->
                </td>
            </tr>
            <tr>
                <td style="font-size:5px;line-height:5px; height: 10px">&nbsp;</td>
            </tr>
            </tbody>
        </table>
    </td>
</tr>
</tbody>

在需要在媒体查询中填写完整大小的表上添加类fullwidth(例如480):

@media only screen and (max-width: 480px){
    .fullwidth,
    .fullwidth tbody,
    .fullwidth tbody > tr,
    .fullwidth tbody > tr > td,
    .fullwidth tbody > tr > th,
    table[class=fullwidth],
    table[class=fullwidth] tbody,
    table[class=fullwidth] tbody > tr,
    table[class=fullwidth] tbody > tr > td,
    table[class=fullwidth] tbody > tr > th
    td[class=main-border] {
        max-width: 100% !important;
        min-width: 100% !important;
        width: 100% !important;
        display: block !important;
        clear: both;

        margin: 0 auto !important;
    }
}

图片src必须使用HTTPS(谷歌代理)

的绝对地址

答案 3 :(得分:0)

我建议使用流体混合方法。使用max-width的嵌套表列以及支持它们的客户端的媒体查询。

  • 构建适用于所有客户端的基本框架。根据我在多个设备上的经验,在Email on Acid上的人创建了一个漂亮的模板,无缝地工作(这个模板运行得非常可怕)。多年来,它作为一个样板工具很好地为我提供了帮助,并且在这里和那里进行了一些小的调整,以改善多年来对HTML电子邮件支持的支持。下载here。他们采用流体混合方法,对表格列使用max-width
  • Outlook不支持max-width,因此您需要求助于Outlook的条件。阅读它here。我上面提到的模板的链接有为其编写的条件。
  • 为支持它们的电子邮件客户端编写媒体查询。请参阅here