【问题标题】:Laravel 5 - Inline CSS in emailLaravel 5 - 电子邮件中的内联 CSS
【发布时间】:2015-06-22 02:24:08
【问题描述】:

我正在处理我的第一个 Laravel 5 项目,并且迫切需要一种从我的电子邮件视图中内联 CSS 的方法。由于 Mandrill 的交付问题,我正在使用 Mailgun(不幸的是,Mandrill 具有 CSS 内联功能,但 Mailgun 没有)。

似乎大多数用于 Laravel 电子邮件内联 CSS 的软件包都已过时,大多数在 4.2 版上都无法正常工作。我试过了:

Inlining CSS when sending an email with Mailgun in Laravel - Antoine Augusti - 似乎没有做任何事情,电子邮件没有内联。似乎 L5 中有几个根本差异打破了这种方法

fedeisas/laravel-mail-css-inliner - 不起作用。有人在Issue 的末尾发布了一些代码,但我不知道如何实现它(也不知道它是否适用于 Laravel 5)。

bweston92/laravel-inline-css-mailer - 看起来很有希望,但似乎没有做任何事情,CSS 没有被内联。

有人有什么建议吗?我真的很希望能够为电子邮件内联 CSS,尤其是当我在发送之前注入 HTML 时(来自 WYSIWYG 编辑器)。

【问题讨论】:

  • 只是一个建议,将您的新课程发布为您问题的答案,而不是将其嵌入您的问题中;)
  • 希望有更好的建议..
  • 我明白了,但是你可以把它作为答案发布而不接受它,期待有人给你一个更好的答案
  • 对,对。将在几分钟内发布。 :)

标签: css laravel laravel-5 html-email blade


【解决方案1】:

受到bweston92/laravel-inline-css-mailer 的启发,我无法开始工作,我使用TijsVerkoyen\CssToInlineStyles 包想出了这个小课程。请随时提供建议或为我指出更好的方向,只是快速需要一些东西。

    <?php namespace App\Library;

    use TijsVerkoyen\CssToInlineStyles\CssToInlineStyles;

    /**

 * Class inlineEmail
 * 
 * Returns rendered Email view with inlined CSS
 * @package App\Library
 */
class inlineEmail {
    /**
     * Filename of the view to render
     * @var string
     */
    private $view;
    /**
     * Data - passed to view
     * @var array
     */
    private $data;

    /**
     * @param string $view Filename/path of view to render
     * @param array $data Data of email
     */
    public function __construct($view, array $data)
    {
        // Render the email view
        $emailView = view($view, $data)->render();
        $this->view = $emailView;
        $this->data = $data;
    }

    /**
     * Convert to inlined CSS
     * 
     * @return string
     * @throws \TijsVerkoyen\CssToInlineStyles\Exception
     */
    public function convert()
    {
        $converter = new CssToInlineStyles();
        $converter->setUseInlineStylesBlock();
        $converter->setCleanup();
        $converter->setStripOriginalStyleTags();
        $converter->setHTML($this->view);
        $content =  $converter->convert();

        return $content;
    }
}

用途:

$data = ['someVar' => 'someValue'];
        $inlineEmail = new inlineEmail('emails.group-email', $data);
        $content  = $inlineEmail->convert();
        Mail::queue('emails.raw', ['content' => $content], function($message) use ($data) {
            $message->subject('Hello World')
                ->to('support@somewhere.org')
                ->bcc($data['recipients']);
        });

然后将转换后的内联 HTML/CSS 传递给 emails.raw,其中仅包含 {!! $content !!}

这是我用于大部分电子邮件的模板 - 它本质上是用于电子邮件的 Bootstrap 的最小版本。我会感谢它的作者,但无法准确追踪我在哪里找到它,如果有人知道请发表评论。还有很多其他模板,只需搜索 Bootstrap Email Template 或 HTML Email Boilerplate。

<!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 name="viewport" content="width=device-width" />
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>Email Title</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
            font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
            font-size: 100%;
            line-height: 1.6;
        }
        img {
            max-width: 100%;
        }
        body {
            -webkit-font-smoothing: antialiased;
            -webkit-text-size-adjust: none;
            width: 100%!important;
            height: 100%;
        }
        a {
            color: #348eda;
        }
        .btn-primary {
            text-decoration: none;
            color: #FFF;
            background-color: #348eda;
            border: solid #348eda;
            border-width: 10px 20px;
            line-height: 2;
            font-weight: bold;
            margin-right: 10px;
            text-align: center;
            cursor: pointer;
            display: inline-block;
            border-radius: 25px;
        }
        .btn-secondary {
            text-decoration: none;
            color: #FFF;
            background-color: #aaa;
            border: solid #aaa;
            border-width: 10px 20px;
            line-height: 2;
            font-weight: bold;
            margin-right: 10px;
            text-align: center;
            cursor: pointer;
            display: inline-block;
            border-radius: 25px;
        }
        .last {
            margin-bottom: 0;
        }
        .first {
            margin-top: 0;
        }
        .padding {
            padding: 10px 0;
        }
        table.body-wrap {
            width: 100%;
            padding: 20px;
        }
        table.body-wrap .container {
            border: 1px solid #f0f0f0;
        }
        table.footer-wrap {
            width: 100%;
            clear: both!important;
        }
        .footer-wrap .container p {
            font-size: 12px;
            color: #666;

        }
        table.footer-wrap a {
            color: #999;
        }
        h1, h2, h3 {
            font-family: "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
            line-height: 1.1;
            margin-bottom: 15px;
            color: #000;
            margin: 40px 0 10px;
            line-height: 1.2;
            font-weight: 200;
        }
        h1 {
            font-size: 36px;
        }
        h2 {
            font-size: 28px;
        }
        h3 {
            font-size: 22px;
        }
        p, ul, ol {
            margin-bottom: 10px;
            font-weight: normal;
            font-size: 14px;
        }
        ul li, ol li {
            margin-left: 5px;
            list-style-position: inside;
        }
        .container {
            display: block!important;
            max-width: 600px!important;
            margin: 0 auto!important; /* makes it centered */
            clear: both!important;
        }
        .body-wrap .container {
            padding: 20px;
        }
        .content {
            max-width: 600px;
            margin: 0 auto;
            display: block;
        }
        .content table {
            width: 100%;
        }
    </style>
</head>

<body bgcolor="#f6f6f6">
<!-- Main Body -->
<table class="body-wrap">
    <tr>
        <td></td>
        <td class="container" bgcolor="#FFFFFF">
            <div class="content">
                <table>
                    <tr>
                        <td align="center">
                            <img src="https://example.com/images/logo.png" alt="Company Logo"/>
                        </td>
                    </tr>
                    <!-- Email content goes here .. -->
                    @yield('content')
                </table>
            </div>
        </td>
        <td></td>
    </tr>
</table>
<!-- /Main Body -->
<!-- Footer -->
<table class="footer-wrap">
    <tr>
        <td></td>
        <td class="container">
            <div class="content">
                <table>
                    <tr>
                        <td align="center">
                            <p>Footer goes here</p>
                        </td>
                    </tr>
                </table>
            </div>
        </td>
        <td></td>
    </tr>
</table>
<!-- /Footer -->
</body>
</html>

扩展此视图的典型电子邮件如下所示:

@extends('emails.template')
@section('content')
    <tr>
        <td>
            <h1>Example Email</h1>
            <p>This is an example email. There are many like it but this one is mine.</p>
        </td>
    </tr>
    <tr>
        <td align="center">
            <p>
                <a href="http://example.com" class="btn-primary">This is a Button</a>
            </p>
        </td>
    </tr>
@endsection

【讨论】:

  • 我也试过你的课,但我看不到你在哪里转换你的css??我在转换函数中添加了这一行: $css = file_get_contents(public_path().'/css/main.css');也可以转换 css,但布局不是我预期的 100%!
  • 你在使用 Laravel 并且通过 Composer 安装了 CssToInlineStyles 吗?
  • 在类中,我在 convert() 方法中转换 CSS。在使用中,您在实例上调用此方法 - $content = $inlineEmail->convert()。您在创建此类的实例时传入常规电子邮件视图,将其内联,然后将生成的内联视图回显到 emails.raw,仅包含 {!! $内容!!}}。你有任何错误吗?
  • 我也是,我添加了要转换的行并在转换函数中设置内联css,一些样式像字体一样应用,,但其他人没有
  • 嗯。稍后我将使用我使用的电子邮件模板更新我的答案。听起来像是 CSS 或内联问题。
猜你喜欢
  • 2018-04-20
  • 2016-03-01
  • 2015-10-01
  • 2015-08-05
  • 2013-05-01
  • 1970-01-01
  • 2018-01-21
  • 2017-06-26
  • 1970-01-01
相关资源
最近更新 更多