小编lio*_*nel的帖子

如何为一块html代码禁用基础或引导样式?

我使用mailgun(虽然这个问题与mailgun无关)来解析收到的电子邮件,而mailgun会将解析后的电子邮件发送到我的服务器.当我收到帖子时,我收到了多部分电子邮件的html代码.我想向我的用户显示html电子邮件,我正在使用rails,所以就像这样

<div>
  <%= raw(message.body_html) %>
</div>
Run Code Online (Sandbox Code Playgroud)

但是,它看起来与我在雅虎或hotmail中查看相同电子邮件时的情况有所不同(我知道不同的电子邮件客户端会以不同的方式显示html电子邮件,但我看起来完全不同).

以下是我自建客户端的外观: html电子邮件显示在我自建的客户端中

这就是雅虎在同一封电子邮件中的样子: 在雅虎的html电子邮件显示

我使用Zurb Foundation作为我的样式框架.但是,我认为电子邮件html带有自己的内嵌样式,我看看它看起来像它的代码,然后它应该看起来与其他客户端相似.

那么显示html电子邮件的最佳做法是什么,假设您获得了一块html代码并希望按原样显示它而不让其他框架覆盖其样式?

此外,是否可以为一段代码禁用Foundation(或用于此问题的twitter引导程序)样式,例如类似

<div>
  <% disable_foundation_styling begin %>
    <%= raw(message.body_html) %>
  <% end %>
</div>
Run Code Online (Sandbox Code Playgroud)

当然"disable_foundation_styling"只是我的想象力.

提前致谢!

!!!!!!!!! 2013年1月1日更新!!!!!!!!!!!!!!!

正如@Alex L.建议的那样,我试过但它并没有像预期的那样安静地工作.iframe像以前一样呈现视图中的所有内容(见下图),这是可以理解的,因为iframe内容只是另一个控制器的视图,在这种情况下rails也包含所有应用程序布局模板.但是,工具栏不是我最关心的问题,它在iframe中的内容与以前完全一样. 在此输入图像描述

我怀疑iframe可能不是这样做的.我看看gmail和yahoo的代码,他们不使用iframe.相反,他们使用非常深的嵌套来呈现html电子邮件.html电子邮件的部分具有相同的yahoo和gmail代码,除了yahoo为每个DOM元素插入自己的id.

所以现在我怀疑有一些基础样式会影响它的外观.

一旦我发现更多,我会更新.

html css ruby-on-rails html-email zurb-foundation

8
推荐指数
1
解决办法
3542
查看次数

标签 统计

css ×1

html ×1

html-email ×1

ruby-on-rails ×1

zurb-foundation ×1