文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用Vue.js和MJML创建响应式电子邮件

2024-04-02 19:55

关注

本篇内容介绍了“如何使用Vue.js和MJML创建响应式电子邮件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

开始MJML

你可以使用npm安装MJML,以将其与Node.js或CLI结合使用:

$ npm install -g mjml

构建我们的电子邮件

首先,请创建一个名为 email.mjml 的文件,尽管你也可以选择其他任何名称。创建文件后,我们的响应式电子邮件将分为以下几部分:

/ 栏目 /

这些部分是我们响应式电子邮件的框架。如上所示,我们的电子邮件将分为六个部分,在我们的 email.mjml 文件中:

<mjml>   <mj-body>     <!-- 公司 Header -->     <mj-section background-color="#f0f0f0"></mj-section>     <!-- 图片 Header -->     <mj-section background-color="#f0f0f0"></mj-section>     <!-- Email 介绍 -->     <mj-section background-color="#fafafa"></mj-section>     <!-- 栏目部分 -->     <mj-section background-color="white"></mj-section>     <!-- 图标 -->     <mj-section background-color="#fbfbfb"></mj-section>     <!-- 社交图标 -->     <mj-section background-color="#f0f0f0"></mj-section>   </mj-body> </mjml>

从上面可以看到,我们正在使用两个MJML组件:mj-body 和 mj-section。mj-body 定义了我们电子邮件的起点,而 mj-section  定义了一个包含其他组件的节。

对于定义的每个部分,还定义了具有各自十六进制值的 background-color 属性。

/ 公司 Header /

我们电子邮件的此部分仅在中心横幅位置包含我们的公司/品牌名称:

<!-- 公司 Header --> <mj-section background-color="#f0f0f0">   <mj-column>     <mj-text  font-style="bold"         font-size="20px"         align="center"         color="#626262">     Central Park Cruise     </mj-text>   </mj-column> </mj-section>

mj-column 组件是用来定义一个列。mj-text 组件用于我们的文本内容,并采取字体样式、字体大小、颜色等样式属性。

/ 图片 Header /

在本部分中,我们将有一个背景图片和一段文字,它们应代表我们的公司口号。我们还会有一个号召性用语按钮,指向一个包含更多详细信息的页面。

要添加图片标题,你必须将该部分的背景颜色替换为  background-url。与第一个标题相似,你将不得不在垂直和水平方向上居中放置文本,padding保持不变。

按钮的 href 设置按钮的位置。为了让背景在列中呈现全宽,将列宽设置为600px,width="600px"。

我们的电子邮件的这一部分将只包含我们的公司/品牌名称的中心横幅位置。

<!-- Image Header --> <mj-section background-url="https://ca-times.brightspotcdn.com/dims4/default/2af165c/2147483647/strip/true/crop/2048x1363+0+0/resize/1440x958!/quality/90/?url=https%3A%2F%2Fwww.trbimg.com%2Fimg-4f561d37%2Fturbine%2Forl-disneyfantasy720120306062055"             background-size="cover"             background-repeat="no-repeat">   <mj-column width="600px">     <mj-text  align="center"              color="#fff"              font-size="40px"              font-family="Helvetica Neue">Christmas Discount</mj-text>     <mj-button background-color="#F63A4D" href="#">       See Promotions     </mj-button>   </mj-column> </mj-section>

要使用图像header,我们将向 jms -section 组件添加 background-url 属性,然后使用 background-size 和  background-repeat 属性设置图像的样式。

对于我们的口号文本块,我们使用 align 属性将文本在水平和垂直方向上居中对齐。你还可以根据需要设置文本颜色,字体大小,字体系列等。

号召性用语按钮是使用 mj-button 组件实现的。background-color 属性允许我们指定按钮的背景色,然后使用 href  指定链接或页面的位置。

/ Email件介绍 /

简介文字将由标题,主体文字和号召性用语组成。

<!-- Intro text --> <mj-section background-color="#fafafa">   <mj-column width="400px">     <mj-text font-style="bold"              font-size="20px"              font-family="Helvetica Neue"              color="#626262">Ultimate Christmas Experience</mj-text>     <mj-text color="#525252">       Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin rutrum enim eget magna efficitur, eu semper augue semper. Aliquam erat volutpat. Cras id dui lectus. Vestibulum sed finibus lectus, sit amet suscipit nibh. Proin nec commodo purus. Sed eget nulla elit. Nulla aliquet mollis faucibus.     </mj-text>     <mj-button background-color="#F45E43" href="#">Learn more</mj-button>   </mj-column> </mj-section>
/ 栏目部分 /

在这封邮件的部分,我们会有两栏:一栏是描述性的图片,二栏是我们的文字块,用来补充第一部分的图片。

<!-- Side image --> <mj-section background-color="white">   <!-- Left image -->   <mj-column>     <mj-image width="200px"               src="https://navis-consulting.com/wp-content/uploads/2019/09/Cruise1-1.png"/>   </mj-column>   <!-- right paragraph -->   <mj-column>     <mj-text font-style="bold"              font-size="20px"              font-family="Helvetica Neue"              color="#626262">       Amazing Experiences     </mj-text>     <mj-text color="#525252">       Lorem ipsum dolor sit amet, consectetur adipiscing elit.        Proin rutrum enim eget magna efficitur, eu semper augue semper.        Aliquam erat volutpat. Cras id dui lectus. Vestibulum sed finibus        lectus.     </mj-text>   </mj-column> </mj-section>

左侧的第一列使用 mj-image 组件指定要使用的图像。该图像可以是本地文件,也可以是远程托管的图像(在我们的情况下是这样)。

右侧的第二列包含两个文本块,一个用于我们的标题,另一个用于主体文本。

/ 图标 /

图标部分将分为三列。你还可以添加更多内容,具体取决于你希望电子邮件的外观。

<!-- Icons --> <mj-section background-color="#fbfbfb">   <mj-column>     <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x0l.png" />   </mj-column>   <mj-column>     <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x01.png" />   </mj-column>   <mj-column>     <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x0s.png" />   </mj-column> </mj-section>

每列都有其自己的 mj-image 组件,用于渲染图标图像。

/ 社交图标 /

本部分将包含指向我们的社交媒体帐户的图标。

<mj-section background-color="#e7e7e7">   <mj-column>     <mj-social>       <mj-social-element name="instagram" />     </mj-social>   </mj-column> </mj-section>

MJML带有 mj-social 组件,可轻松用于显示社交媒体图标。在我们的电子邮件中,我们使用了 Twitter  mj-social-element。

全部放在一起

至此,我们已经实现了所有部分,完整的 email.mjml 应该如下所示:

<mjml>   <mj-body>     <!-- Company Header -->     <mj-section background-color="#f0f0f0">       <mj-column>         <mj-text  font-style="bold"                  font-size="20px"                  align="center"                  color="#626262">           Central Park Cruises         </mj-text>       </mj-column>     </mj-section>     <!-- Image Header -->     <mj-section background-url="https://ca-times.brightspotcdn.com/dims4/default/2af165c/2147483647/strip/true/crop/2048x1363+0+0/resize/1440x958!/quality/90/?url=https%3A%2F%2Fwww.trbimg.com%2Fimg-4f561d37%2Fturbine%2Forl-disneyfantasy720120306062055"                 background-size="cover"                 background-repeat="no-repeat">       <mj-column width="600px">         <mj-text  align="center"                  color="#fff"                  font-size="40px"                  font-family="Helvetica Neue">Christmas Discount</mj-text>         <mj-button background-color="#F63A4D" href="#">           See Promotions         </mj-button>       </mj-column>     </mj-section>     <!-- Email Introduction -->     <mj-section background-color="#fafafa">       <mj-column width="400px">         <mj-text font-style="bold"                  font-size="20px"                  font-family="Helvetica Neue"                  color="#626262">Ultimate Christmas Experience</mj-text>         <mj-text color="#525252">           Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin rutrum enim eget magna efficitur, eu semper augue semper. Aliquam erat volutpat. Cras id dui lectus. Vestibulum sed finibus lectus, sit amet suscipit nibh. Proin nec commodo purus. Sed eget nulla elit. Nulla aliquet mollis faucibus.         </mj-text>         <mj-button background-color="#F45E43" href="#">Learn more</mj-button>       </mj-column>     </mj-section>     <!-- Columns section -->     <mj-section background-color="white">       <!-- Left image -->       <mj-column>         <mj-image width="200px"                   src="https://navis-consulting.com/wp-content/uploads/2019/09/Cruise1-1.png"/>       </mj-column>       <!-- right paragraph -->       <mj-column>         <mj-text font-style="bold"                  font-size="20px"                  font-family="Helvetica Neue"                  color="#626262">           Amazing Experiences         </mj-text>         <mj-text color="#525252">           Lorem ipsum dolor sit amet, consectetur adipiscing elit.            Proin rutrum enim eget magna efficitur, eu semper augue semper.            Aliquam erat volutpat. Cras id dui lectus. Vestibulum sed finibus            lectus.         </mj-text>       </mj-column>     </mj-section>     <!-- Icons -->     <mj-section background-color="#fbfbfb">       <mj-column>         <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x0l.png" />       </mj-column>       <mj-column>         <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x01.png" />       </mj-column>       <mj-column>         <mj-image width="100px" src="https://191n.mj.am/img/191n/3s/x0s.png" />       </mj-column>     </mj-section>     <!-- Social icons -->     <mj-section background-color="#e7e7e7">       <mj-column>         <mj-social>           <mj-social-element name="instagram" />         </mj-social>       </mj-column>     </mj-section>   </mj-body> </mjml>

运行我们的应用程序

现在我们已经完成了电子邮件的构建,我们可以继续对其进行编译以查看其外观。为此,我们在终端中键入以下内容:

mjml -r email.mjml -o .

MJML完成编译后,你现在应该在同一目录中看到一个 email.html 文件。 使用你喜欢的电子邮件客户端或浏览器打开它,它的外观应类似于下图:

如何使用Vue.js和MJML创建响应式电子邮件

总结

正如我们刚才看到的,MJML帮助我们生成跨多个浏览器和客户机响应的高质量、漂亮的HTML电子邮件。

“如何使用Vue.js和MJML创建响应式电子邮件”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯