2 回答
TA贡献1772条经验 获得超8个赞
正如文档所说:定义一个 Twig 命名空间,该命名空间指向存储图像的任何目录,例如:
# config/packages/twig.yaml
twig:
paths:
# point this wherever your images live
public/build/: build
接下来,在您的电子邮件模板中:
{# '@build/' refers to the Twig namespace defined earlier #}
<img src="{{ email.image('@build/logo.png') }}" alt="Logo">
<img src="{{ email.image('@build/subdir/logo.png') }}" alt="Logo">
如果构建的图像有一些随机后缀,这将不起作用,例如在配置文件.enableVersioning()中定义的时候。webpack.config.js
如果您启用了版本控制策略,您可以执行以下操作:
# config/packages/twig.yaml
twig:
paths:
public/: public
并使用字符串 concat 运算符构建模板名称~:
{# '@public' refers to the Twig namespace defined earlier #}
<img src="{{ email.image('@public' ~ asset('build/logo.png')) }}" alt="Logo">
TA贡献1796条经验 获得超7个赞
有两种方法可以在邮件中获取图像。第一个是嵌入的图像,第二个只是指向网络上某处图像的链接。如果要嵌入图像,则必须将图像附加到邮件中:
$attachment = Swift_Image::newInstance($data, $filename, $mimeType)
->setDisposition('inline');
$cid = $message->embed($attachment); // Generates "cid:something"
重要的是像这样显示您的图像:
<img src="cid:something" ... />
所以你必须像这样渲染你的模板:
$twig->render('email/email.html.twig', [
'cid' => $cid,
...
]);
在你的树枝模板中:
<img src="{{ cid }}" ... />
添加回答
举报
