现在,即使是创建最基本的网站,程序员也必须使用现代的功能和技术。甚至像为你的朋友创建简单的投资组合这样的基本项目也可能涉及到一些问题,比如从联系人表单接收数据。有很多方法可以读取这些数据。你可以将表单与数据库连接起来,然后从数据库中读取传入的消息来实现功能,但这样做会给不懂技术的客户造成困难。
( Q) u) _6 R! u* Y你为什么不通过发送电子邮件传输信息?
) D8 m5 `+ u6 }' O: w( e* k 不使用数据库就能接收到传入的消息,绝对是最佳选择,也是最方便用户的选择。但问题来了—如何实现呢?你可能认为需要使用某种后端语言。; H L7 {. C3 E8 ^1 j& O" ?
8 @; S9 R# ?8 q) N8 y9 e u2 x
实际上,你不必使用任何如 php 或 python 这种后端语言,你甚至不需要用到 node.js! 你需要的就是一个简单的 EmailJS 库(后附本项目源码)。; o" a. H% _3 E+ O* ?) U
本文将介绍下面两个重要功能:1 v# R9 t) G& S) C1 |9 [
- 配置 emailjs 帐户
- 使用 JS 发送电子邮件8 o6 E' G% m0 U
请注意,在项目中使用了 gulp 和 webpack,在 src 文件夹存放源码,dist 存放最终发布版本的代码。下面将分 5 个步骤向你展示如何从头开始构建电子邮件发送器。
2 I; @* M/ E6 g1 f步骤1-用 HTML 创建表单$ Q6 @; X/ @$ L+ i
首先需要创建一个 HTML 表单。你不必放置像 required 或 max 这种验证属性,因为稍后,preventDefault() 函数将在你的提交事件上运行,它会让这些属性的处理失效。
% z/ F1 y* b( `8 h 表单中最重要的是为每个输入放置 name 属性,后面会用到。简单的表单是这样的:
7 B+ A! J2 p: k) m- Y src/html/index.html
- x5 m3 O# m5 M6 o<form class="form">
<input name='name' type="text" placeholder="Your name..." class="form__input" />
<input name='topic' type="text" placeholder="Topic..." class="form__input" />
<textarea name='message' type="text" placeholder="Your Message..." class="form__input" ></textarea>
<input type="submit" value="send" class="form__input form__input--button">
</form> 步骤2-注册成为 email 用户7 K5 o, {7 q9 O" `. u9 o* `& _
要配置你的电子邮件,你必须注册电子邮件服务。别担心—使用这个网站非常方便和省时。登入后,系统会询问你的电子邮件服务,它位于个人电子邮件服务区(personal email service)。在例子中选择的 gmail。
; v1 U4 V8 l& s! M: b
+ A# }$ y0 _% n" U \ 然后,你需要连接你的 gmail 帐户。这将用来发送电子邮件给你客户。例如,如果你关联了 xyz@gmail.com 账户,你后续发送的邮件都将从这个邮箱发出。所以不要担心“ Send email on your behalf” 这个授权信息—这正是你需要的!
2 m: H: B4 v$ S F( M: [
% W( u0 m0 X5 C" Z$ i! ~
连接完 gmail 账户后,点击添加服务(add service)按钮。
) K5 U; x' O, A# f步骤3-创建邮件模板
# [/ E9 J( S5 E5 A4 K9 G 如果你已经成功连接了你的 gmail 账户,你现在应该在信息中心中。现在需要创建电子邮件模板了。切换到电子邮件模板卡,并单击创建一个新的模板(create a new template)。界面非常友好,所以创建模板不会有任何问题。你可以选择模板的名称和 ID。称之为“我的神奇模板(my_amazing_template)”。0 ]$ r1 |& {2 L; w4 k& y& R n
* E# ?, P0 X+ I8 c2 l; B
接下来,你必须指定邮件的内容。模板的变量值来自 input 中的 `name` 属性。你已将变量插入`{{{}}}`符号中。1 R3 q4 T! K& N% t8 z' I
不要忘记在“收件人”部分 (右侧) 添加电子邮件地址。你的电子邮件将被发送到该电子邮件地址上。这是一个简单模板,它使用来自 HTML 表单里的 3 个变量,还指定了接收电子邮件的主题。
0 M% X' D9 z" U. C, S) H
# w/ d8 \& q7 X
步骤4-保存 API 密钥/ K! R6 ~/ R. @7 {
这部分没什么特别的。Emailjs 共享授权 API 密钥,将在发送电子邮件时使用。当然,放这些钥匙最好的地方是`.env` 配置。但是因为这里使用的是简单的静态文件,不想使用服务器配置,所以将它们保存在 apikeys 文件中,然后再将它们导入。1 s. R* @: J. P0 ~) A" S" [ L
1、你的 USER_ID 位于 Account > API Keys 菜单下。
# f E" j& ?( b8 D' F' j
$ _( G6 B# F7 K
2、TEMPLATE_ID 位于模板的标题下面。5 v+ }; h! j) C3 a* J% @5 O' j: o
. c6 }+ i% s! a7 Z 这是基于不存在的 keyssrc / js / apikeys. js 的示例配置。
) W+ }" x" J+ G8 h, g- J src/js/apikeys.js0 {: F' j3 Q0 [
export default {
USER_ID :'user_DPUd-rest-of-my-id',
TEMPLATE_ID:'my_amazing_template'
} 如果需要将源码发布到 GITHUB,不要忘记将 APIKEYS 文件添加到 .GITIGNORE文件中2 E7 C( U5 I0 B" x. Z5 m/ N
步骤5-发送电子邮件
9 j# Y: W2 [0 _/ k1 o& {, M& T+ ? 现在是该项目最后也是最重要的部分的了。现在我们必须使用 javascript 发送电子邮件。
2 a3 q: `. i# Y* S3 Z, U首先,你必须下载 emailjs 包。& ]- w: `" a2 w, ]
npm i emails-com 然后,转到 js 文件,导入库和 apikeys。7 E+ @4 B1 a6 g. x9 I
src/js/main.js$ k) D4 ^2 f3 f! I7 Z
import emailjs from 'emailjs-com'
import apiKeys from './apikeys' 现在是编写发送电子邮件功能的时候了
0 R1 Q. [1 U6 k* O. o src/js/main.js
3 m- J" k+ }3 F1 ]$ {const sendEmail = e => {
e.preventDefault()
emailjs
.sendForm('gmail', apiKeys.TEMPLATE_ID, e.target, apiKeys.USER_ID)
.then(
result => {
console.log(result.text)
},
error => {
console.log(error.text)
}
)
} sendForm 函数有4个参数:
) {, p. I: U! K5 X0 z 你的电子邮件的 ID,在这里:
5 n; K ~4 l5 G* Q$ p
- f' \; ?/ k# f/ G$ q9 e
- TEMPLATE_ID 来自 apikey 文件
- 事件对象来自你的表单提交
- USER_ID 来自 apikey 文件
8 ^+ }; u- `3 e, p 最后,查找表单并添加提交事件监听器:! M$ C; w% X. r _2 j) S
src/js/main.js* n+ Q8 K8 i6 n3 f2 C" ]
const form = document.querySelector('.form')
form.addEventListener('submit',sendEmail) 正如前面提到的,由于 `preventDefault()` 函数,属性验证将无法工作。你必须使用 JS 自己进行验证和清除输入。以上就是全部内容,接下来让我们测试一下。
4 V/ m& g0 L9 }: m' t& m 填写页面上的表单并发送。
$ M: C8 Z) {, X8 p* W5 a* ^
$ X# z- }/ v; D1 w4 K, ] 现在收到了电子邮件,内容正是根据我们的模板和表单数据渲染出来的。+ G9 g& N8 i- ^5 d: C
8 q5 p/ ^: b' D- E. W" y 通过上图可以看出,所有的变量的值都填充到了正确的位置上。
* d" H) b" j5 `: t2 e7 r" V) `, c 配套代码在这里: https://github.com/iwaniukooo11/email-sender |