者 | Mateusz Iwaniuk
譯者 | 明明如月,責編 | 夕顏
出品 | CSDN(ID:CSDNnews)
文章配套代碼: https://github.com/iwaniukooo11/email-sender
現在,即使是創建最基本的網站,程序員也必須使用現代的功能和技術。甚至像為你的朋友創建簡單的投資組合這樣的基本項目也可能涉及到一些問題,比如從聯系人表單接收數據。有很多方法可以讀取這些數據。你可以將表單與數據庫連接起來,然后從數據庫中讀取傳入的消息來實現功能,但這樣做會給不懂技術的客戶造成困難。
你為什么不通過發送電子郵件傳輸信息?
不使用數據庫就能接收到傳入的消息,絕對是最佳選擇,也是最方便用戶的選擇。但問題來了—如何實現呢?你可能認為需要使用某種后端語言。
實際上,你不必使用任何如 php 或 python 這種后端語言,你甚至不需要用到 node.js!你需要的就是一個簡單的EmailJS 庫。
本文將介紹下面兩個重要功能:
配置 emailjs 帳戶
使用 JS 發送電子郵件
請注意,在我的項目中,我使用了 gulp 和 webpack,我在 src 文件夾存放源碼,dist 存放最終發布版本的代碼。
我將分 5 個步驟向你展示如何從頭開始構建電子郵件發送器。
步驟1-用 HTML 創建表單
首先需要創建一個 HTML 表單。你不必放置像 required 或 max 這種驗證屬性,因為稍后,preventDefault 函數將在你的提交事件上運行,它會讓這些屬性的處理失效。
表單中最重要的是為每個輸入放置 name 屬性,后面會用到。
我的非常簡單的表單是這樣的:
src/html/index.html
<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 用戶
要配置你的電子郵件,你必須注冊電子郵件服務。別擔心—使用這個網站非常方便和省時。
登入后,系統會詢問你的電子郵件服務,它位于個人電子郵件服務區(personal email service)。在我的例子中,我選擇了 gmail。
然后,你需要連接你的 gmail 帳戶。這將用來發送電子郵件給你客戶。例如,如果你關聯了 xyz@gmail.com 賬戶,你后續發送的郵件都將從這個郵箱發出。所以不要擔心“ Send email on your behalf” 這個授權信息—這正是你需要的!
連接完 gmail 賬戶后,點擊添加服務(add service)按鈕。
步驟3-創建郵件模板
如果你已經成功連接了你的 gmail 賬戶,你現在應該在信息中心中。現在需要創建電子郵件模板了。
切換到電子郵件模板卡,并單擊創建一個新的模板(create a new template)。界面非常友好,所以創建模板不會有任何問題。
你可以選擇模板的名稱和 ID。我稱之為“我的神奇模板(my_amazing_template)”。
接下來,你必須指定郵件的內容。
模板的變量值來自 input 中的 `name` 屬性。你已將變量插入`{{{}}}`符號中。
不要忘記在“收件人”部分 (右側) 添加電子郵件地址。你的電子郵件將被發送到該電子郵件地址上。截圖中的收件人郵箱是我自己的公司郵箱。
這是我的簡單模板,它使用來自 HTML 表單里的 3 個變量。我還指定了接收電子郵件的主題。
步驟4-保存 API 密鑰
這部分沒什么特別的。Emailjs 共享授權 API 密鑰,將在發送電子郵件時使用。當然,放這些鑰匙最好的地方是`.env` 配置。但是因為我使用的是簡單的靜態文件,我不想使用服務器配置,所以我將它們保存在 apikeys 文件中,然后再將它們導入。
你的 USER_ID 位于 Account > API Keys 菜單下。
TEMPLATE_ID 位于模板的標題下面。
這是我基于不存在的 keyssrc / js / apikeys. js 的示例配置.
src/js/apikeys.js
export default {
USER_ID :'user_DPUd-rest-of-my-id',
TEMPLATE_ID:'my_amazing_template'
}
如果需要將源碼發布到 GITHUB,不要忘記將 APIKEYS 文件添加到 .GITIGNORE文件中
現在是該項目最后也是最重要的部分的了。現在我們必須使用 javascript 發送電子郵件。
首先,你必須下載 emailjs 包。
npm i emails-com
然后,轉到 js 文件,導入庫和 apikeys。
src/js/main.js
import emailjs from 'emailjs-com'
import apiKeys from './apikeys'
現在是編寫發送電子郵件功能的時候了
src/js/main.js
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個參數:
你的電子郵件的 ID,在這里:
TEMPLATE_ID 來自 apikey 文件,
事件對象來自你的表單提交
USER_ID 來自 apikey 文件,
最后,查找表單并添加提交事件監聽器:
src/js/main.js
const form = document.querySelector('.form')
form.addEventListener('submit',sendEmail)
正如我前面提到的,由于 `preventDefault` 函數,屬性驗證將無法工作。你必須使用 JS 自己進行驗證和清除輸入。
以上就是全部內容,接下來讓我們測試一下。
填寫頁面上的表單并發送。
我收到電子郵件,內容正是根據我們的模板和表單數據渲染出來的。
通過上圖可以看出,所有的變量的值都填充到了正確的位置上。
通過本文的介紹你會發現用 JS 發送郵件并非難事。
使用 emailjs,你可以簡單的方式發送電子郵件。
我相信你未來的用戶會很高興收到來自他們網頁上表單填寫數據的t郵件,相信本文對你有幫助。
這篇文章的配套代碼在這里: https://github.com/iwaniukooo11/email-sender
原文鏈接:
https://dev.to/iwaniukooo11/send-e-mails-directly-from-front-end-with-js-5d7d
本文為CSDN翻譯文章,轉載請注明出處。
?我們想研發一個機器學習框架,6 個月后失敗了
?生產型機器學習已經沒那么困難了?
?視頻 | 你不知道的"開源"60年秘史
?GitHub標星10,000+,Apache項目ShardingSphere的開源之路
?阿里技術專家告訴你,如何畫出優秀的架構圖?
?加拿大API平臺如何做到30%為中國明星項目?創業老兵這樣說……
文是outlook的實用基礎篇,都是圖片的格式,需要的小伙伴可以把這個連載作為入門的教程進行學習掌握。當然了,outlook不僅是商務辦公用,你在自己的電腦上也可以將此工具作為平時收郵件的默認工具哦。
課程都是從實際工作中而來,對常見操作進行講解,基于2010版本,其他版本均通用,以圖片為主,每一步都清晰明了。大家可以自行安裝好郵件客戶端Outlook后進行實踐學習即可。
Outlook的基本設置跟其他office軟件都是相通的,我們直接先打開從選項卡中的文件說起,如下:
點擊”選項”:
如果你的電腦上outlook不是你的常用或默認郵件程序,請不用勾選上述的”啟動選項”框;當然,如果是,強烈建議你將此設置為你的默認郵件系統,勾選此框。
我們再來看左側欄中的選項 – 郵件,這里我用紅色標注了格式部分,如下:
此處顯示的是郵件編輯的三種格式,那么這三種格式的區別分別在哪里呢?
我們先看HTML(超文本鏈接語言):
我們在編寫郵件的時候,也可以直接通過菜單中的按鈕進行郵件格式的轉換,如下所示:
當我們插入附件的時候,我們可以看到專門有一個附件欄,附件將放入其中,我們在正文中輸入帶鏈接的文本的時候,會自動切換成超鏈接的形式,正文中如果添加圖片,也可以直接在正文中顯示出來。對于正文中的文字部分,我們是可以進行字體顏色等的設置的。
再來看看RTF(Rich Text Format),翻譯過來是:豐富的語言格式。如下:
我們同樣用上述方法比較,這個時候插入的附件,就不再是單獨的一欄了,而是直接嵌入到了我們的郵件正文之中。當然,我們的網址仍然是以超鏈接的形式存在,圖片也是直接顯示在正文中。同樣字體顏色這些也是可以進行設置的。
最后一個是純文本的格式,對于它來說,支持的格式相當少。正文中無法插入圖片,可以插入附件,顯示的方式跟HTML一樣,也是在一個單獨的欄中體現;無法加入帶鏈接的文本,正文中字體樣式,大小,顏色什么的無法進行設置。大家可能覺得一無是處我干嘛用這個啊?!它的好處是:可在接收它的人員所使用的任何電子郵件軟件中正確顯示,還能有效防止病毒呢。
所以關于這個格式我們總結一下:HTML與RTF格式類似,這個設置沒有具體章法,都是根據自己的喜好而定。如果對方告知你收到的郵件是亂碼或者格式錯亂,請將郵件格式改為純文本。
另外,下面這個特別提醒大家,關于郵件的簽名:
簽名雖然不起眼,但是非常非常重要!
點擊上圖中的簽名按鈕,彈出:
點擊上圖中的“新建”按鈕,彈出:
給你的簽名取個名字,方便調用。確定之后在“編輯簽名”欄中輸入內容:
對于工作郵件,你可以輸入:
姓名、職位、部門、分機號或其他聯系方式、公司名稱或寄信地點等必要信息。至少你要讓人家知道你是誰!
完成上述之后,點擊保存或確定即可。
一般第一次溝通,別人不知道你是誰的情況下,我們使用正規的簽名,也顯得正式和尊重,熟悉了之后,我們就可以使用短簽名,所以Outlook比較人性化的提供了不同場景下使用不同簽名的方式,大家可以看到在選擇默認簽名的時候有兩個選項,一個是新郵件使用的簽名,另一個是答復或轉發郵件時使用的簽名。你不同的郵箱也可以設置不同的簽名。
上述同樣的方法進行短簽名的編輯之后,我們可以看到我最后的設置如下:
再來說說郵件的閱讀窗格,有時候我們打開outlook的時候,突然發現一片未讀郵件,強迫癥忍不了,所以我們可以進行調整默認已讀方式,不用雙擊郵件就可以直接將郵件的狀態由未讀轉為已讀。
點擊“閱讀窗格”,彈出:
勾選第一個,當郵件在等待設置的時間后直接自動變為已讀;
勾選第二個,只要點擊未讀郵件就直接變成已讀;
勾選第三個,空格鍵直接就可以滾動閱讀郵件;
這些也是根據自己的習慣進行設置就好。
接下來是郵件到達的提示:
默認上述勾選,點擊“桌面通知設置”,彈出:
我們可以根據上述兩個滑標進行通知的顯示時長以及透明度的設置。
繼續往下,我們來看看日歷界面及基本設置。
在選項中,我們可以通過調整工作時間及工作周選項來設置日歷的顯示方式,如下:
在日歷的界面中,我們可以給別人設定閱讀自己日歷的權限,一般情況,我們看對方的日歷是下面這種情況,如果你想了解你的下屬或讓你的下屬知道你的形成,我們可以將日歷權限進行開放。
在日歷選項中,我們點擊“忙/閑選項”:
彈出的對話框如下:
添加完人員之后,你在讀取那里就可以選擇“詳細信息”,確定即可。這樣在對方的郵箱日歷界面你看到的就是下面這種:
除此之外,我們也不用擔心不知道現在是多少周的問題了。同樣可以設置:
勾選之后,就是下面這樣了:
當然如果你在外企工作,有可能涉及兩個時區,那么我們同樣可以進行設置,方便安排一些跨國的會議等。
顯示的界面如下:
今天先到這里,下節繼續。
親愛的讀者,我們已經成功地發送了簡單的文本郵件。但在實際應用中,我們可能還需要發送格式更加豐富的HTML郵件,或者包含附件的郵件。今天,我們就來探索如何使用Python來構建并發送這樣的郵件。
HTML郵件可以讓你的郵件內容更加豐富多彩,包含圖片、鏈接、樣式等。在Python中,我們同樣可以使用email模塊來構建HTML郵件。
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
# HTML郵件正文內容
html_content = """
<html>
<head></head>
<body>
<h1>Hello, this is an HTML email from Python!</h1>
<p>Here's a <a href="https://www.python.org">link to Python's website</a>.</p>
<img src="cid:image1"> <!-- 注意:這里使用了cid引用,稍后我們將添加圖片附件 -->
</body>
</html>
"""
# 創建一個多部分郵件對象
msg = MIMEMultipart('related')
msg['From'] = 'your_email@gmail.com'
msg['To'] = 'receiver_email@example.com'
msg['Subject'] = 'HTML Email with Python'
# 添加HTML郵件正文
msg_alternative = MIMEMultipart('alternative')
msg.attach(msg_alternative)
html_part = MIMEText(html_content, 'html', 'utf-8')
msg_alternative.attach(html_part)
# (可選)添加圖片附件(這里僅為示例,實際發送時請確保圖片文件存在)
# 注意:由于示例中HTML中引用了圖片,我們需要在郵件中添加這個圖片作為附件,并使用cid引用
# 這里為了簡化,我們略過實際文件讀取和添加的過程,僅展示邏輯
# ... 添加圖片附件的代碼會涉及到打開文件、讀取內容、創建MIMEImage對象,并設置Content-ID為"image1"
# 發送郵件(假設SMTP連接和登錄已經完成)
# ... 使用smtplib發送msg對象,與之前的示例類似
注意:上面的代碼示例中,關于添加圖片附件的部分被省略了,因為它涉及到文件I/O操作和MIMEImage對象的使用,這可能會讓示例變得復雜。在實際應用中,你需要讀取圖片文件,創建MIMEImage對象,并將其附加到郵件中,同時確保HTML中的<img>標簽通過cid屬性正確引用該圖片。
發送帶附件的郵件與發送HTML郵件類似,但你需要創建一個多部分郵件(MIMEMultipart),并為每個部分(文本、HTML、附件等)設置不同的MIME類型。
from email.mime.base import MIMEBase
from email import encoders
# 假設我們要發送一個名為"example.txt"的文本文件作為附件
filename = 'example.txt'
# 讀取文件內容并編碼為base64
with open(filename, 'rb') as attachment:
part = MIMEBase('application', 'octet-stream')
part.set_payload((attachment).read())
encoders.encode_base64(part)
# 添加文件頭信息
part.add_header('Content-Disposition', "attachment; filename= %s" % filename)
# 將附件添加到郵件中
msg.attach(part)
# 現在,msg對象包含了文本(或HTML)和附件,你可以使用smtplib發送它
# ... 發送郵件的代碼與之前相同
恭喜你,現在你已經掌握了使用Python發送文本郵件、HTML郵件以及帶附件郵件的技能!這些技能將幫助你在自動化任務、通知系統或任何需要郵件通信的應用程序中大展拳腳。記得在實踐中不斷探索和嘗試,你會發現Python在郵件處理方面的更多可能性。
*請認真填寫需求信息,我們會在24小時內與您取得聯系。