10

我正在做一份报告,在报告中我必须呈现来自不同提供商的电子邮件,这些电子邮件带有自己的 css(通常是内联 css,但有时它们应用一般样式)。我通常使用 iframe 来封装 css,所以它不会破坏我的,但我现在不能使用它。

有没有办法在不使用 iframe 的情况下封装 css?

这是我遇到的问题的一个例子:

<html>
  <head>
    <style>
      // I enclose it to content so it doesn't override the email css 
      #my_content table, #my_content p {
        color: black;
      }
    </style>
   </head>
   <body>  
     <div id='my_content'>
      ... some stuff ...
     <div id='email'>
        <html>
          <head>
            <style>
              table {
                margin-left: 100cm; // screws up all my tables
              } 
              .... some styles that should only apply inside the email div ...
            </style>
          </head>
          <body>
            .... email content ...
          </body>
        </html>
      </div>
    </div>
  </body>
</html>

我可以提取 html 结构并获取正文中的内容,但并不是我所有的电子邮件都会看起来像它应该的那样。此外,html 必须是有效的,所以任何建议都会很棒!

4

2 回答 2

5

您可以#email添加到您的 css 选择器,使它们仅适用于您的 div。

例如,改变

.classname { display: block }

#email .classname { display: block }

编辑:如果您无法按照 arxanas 的建议控制电子邮件 CSS,请考虑使用LESS。Less 是一个 CSS 预处理器,允许嵌套 CSS 选择器。如果你包含 less.js,那么你可以这样做:

#email {
    CSS goes here
}

less.js 将解析它并将其转换为 CSS。

于 2012-08-28T20:16:04.463 回答
1

您可以尝试检查电子邮件 css 部分是否与您自己的类名发生冲突。我刚刚发现这篇文章可能对您有所帮助: Listing known CSS classes using Javascript

于 2012-08-28T20:15:49.590 回答