Laravel 5 - 电子邮件中的内联 CSS

Posted

技术标签:

【中文标题】Laravel 5 - 电子邮件中的内联 CSS【英文标题】:Laravel 5 - Inline CSS in email 【发布时间】: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 编辑器)。

【问题讨论】:

只是一个建议,将您的新课程发布为您问题的答案,而不是将其嵌入您的问题中;) 希望有更好的建议.. 我明白了,但是你可以把它作为答案发布而不接受它,期待有人给你一个更好的答案 对,对。将在几分钟内发布。 :) 【参考方案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" />
                        </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 或内联问题。

以上是关于Laravel 5 - 电子邮件中的内联 CSS的主要内容,如果未能解决你的问题,请参考以下文章

将外部 CSS 转换为内联 CSS 用于 Rails 中的邮件

使用 Summernote 在 Laravel 中动态内联附件

Laravel 5.3 通知与可邮寄

如何在 laravel 刀片语法按钮中添加内联 css?

如何在 laravel 5.2 后同时获取电子邮件和密码

Gmail 将“position:relative”删除为内联 CSS(电子邮件模板)