2024-01-09 如何迁移 Newsletter 到 phplist
参考链接:
phplist:https://github.com/phpList/phplist3
前言
最近突然收到 Tinyletter 发的邮件,说是 Tinyletter 将在 2024 年 2 月 29 日后关闭,这可让我虎躯一震,毕竟前不久(去年)才刚写过一篇博客来推荐 Tinyletter 呢!(详见:2023-09-24 如何通过 Tinyletter 订阅 RSS)
于是就问了下万能的 ChatGPT,有没有开源的邮件订阅系统(Newsletter),毕竟我可不想第二次迁移了。
ChatGPT 也是不负众望,给我推荐了几个开源的邮件订阅系统。
经过一番调研,感觉phplist还是蛮不错的,既有开源版本,也可以直接使用他们部署的版本,故特此记录。
正文
注册
废话不多说,先注册个账号再说,前往官网注册即可。
第一步是叫你取个名字,这个名字会用来当子域名,随便取即可,自己记得住就行了。
第二步就是填邮箱和密码了,和 Tinyletter 一样,还是推荐用国外的邮箱,比如谷歌邮箱。但国内的邮箱应该也是可以用的,只要不被误认为垃圾邮件就好了。
第三步这里就不截图了,主要是补充信息,可以不填。
完成之后就可以点击确定了,之后在邮箱里点下确认邮件,然后再等待一小会儿,就可以进入你的主页了。
主页
【PS:这里如果你仔细观察的话,就可以注意到当前域名是之前取的名称+hosted.phplist.com
,例如xxxx.hosted.phplist.com
】
主页默认进来是全英文的,虽然有中文选项,但翻译烂的一批,还不如英文版看的舒服。
如果真的像我一样是个英语苦手的话,可以借助翻译工具使用,反正只需要知道各个页面是干什么用的就行了。
到了这里,各位读者最关心的就是 phplist 要怎么实现订阅页面(就像下面的 Tinyletter 这样),下面就来说明这个问题
订阅页面
phplist 有关的内容位于 My account
下面的AJAX Integration
,参考上面的内容即可做出差不多的效果。
第一步是创建一个订阅页面,在subscribe
页面操作即可。
然后就是记下 id,我这里是 1。
1 2 3 4 5 6 7 8
| <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script> <script type="text/javascript" src="https://s3.amazonaws.com/phplist/phplist-subscribe-0.2.min.js"></script>
<div id="phplistsubscriberesult"></div> <form action="https://caomeiyouren.hosted.phplist.com/lists/?p=subscribe&id=1" method="post" id="phplistsubscribeform"> <input type="text" name="email" value="" id="emailaddress" /> <button type="submit" id="phplistsubscribe">Subscribe to our newsletters</button> </form>
|
然后就可以看到订阅按钮了。
怎么说呢,没加样式的情况下确实简单的有些过分了。
话说如此,你就说不能不用吧!
点开之后就可以开看到订阅页面,呃,怎么说呢,虽然相较于 Tinyletter 确实丑了点,但也不是不能用,现阶段还是能用就行了,美化的事之后再考虑。
到此为止,就已经初步实现了邮件订阅功能,如果只是能用就行的话,可以到此结束了
美化
不过,作为一个多年老前端,对于如此丑陋的前端页面是无法容忍的,所以需要狠狠的美化一下!把以前的代码拿过来抄一下!
美化的部分主要是两个,一个是邮件订阅按钮,毕竟长得那么丑,读者看了就不想订阅了;另一个是邮件订阅页面,长得太丑也很劝退读者!
美化订阅按钮
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
| <!DOCTYPE html> <html lang="zh-CN">
<head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Document</title> <script type="text/javascript" src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script> <script type="text/javascript" src="https://s3.amazonaws.com/phplist/phplist-subscribe-0.2.min.js"></script> <style>
.sub_box { display: block; box-sizing: border-box; }
#sub-form, #phplistsubscribeform { border: 0; padding: 3px; text-align: center; display: flex; justify-content: center; }
p#subscribe-email, p#subscribe-submit { margin: 0; box-sizing: inherit; display: block; }
p#subscribe-email { flex-grow: 1; max-width: 400px; }
.sub-input { font-size: 16px; padding: 15px 23px 15px 23px; margin: 0px; border-radius: 0px; border-width: 1px; line-height: 1.3; box-shadow: none; }
.input-email { margin: 0; width: 100%; color: #666; border: 1px solid #ccc; max-width: 100%; }
.input-submit { margin: 0px; margin-left: 10px; border-color: transparent; border-style: solid; background-color: #222; color: #fff; box-sizing: border-box; min-width: auto !important;
} </style>
</head>
<body>
<div class="pagination"> <div class="pagination__title"> <span class="pagination__title-h">📮邮件订阅</span> <hr /> </div> <p style="text-align: center;">想我每次发布新东西时都收到电子邮件吗?</p> <div class="sub_box"> <div id="phplistsubscriberesult"></div> <form id="phplistsubscribeform" action="https://caomeiyouren.hosted.phplist.com/lists?p=subscribe&id=1" method="post"> <p id="subscribe-email"> <input type="email" name="email" value="" id="emailaddress" placeholder="输入你的邮箱地址..." required class="sub-input input-email" /> </p> <p id="subscribe-submit"> <button type="submit" id="phplistsubscribe" class="sub-input input-submit">订阅</button></p> </form> </div> </div>
</body>
</html>
|
样式上还是采用了原来的方案,如果要自己用的话请修改 action
字段中的链接!
可以前往本文底部查看效果。
美化邮件订阅页面
该部分暂时还未美化,但填充了一点内容。
总结
本文介绍了如何迁移邮件订阅系统(Newsletter)到 phplist。博客首先提到了 Tinyletter 将在 2024 年 2 月 29 日关闭的消息,引发了作者的关注。作者经过调研后选择了 phplist 作为替代方案,并详细介绍了 phplist 的注册流程和主页界面。博客还提供了如何创建订阅页面的步骤,并附上了相应的代码。最后,博客指出虽然 phplist 的界面相对较简单,但可以通过美化订阅按钮和邮件订阅页面来改善用户体验。整体而言,该博客提供了一个详细的指南,帮助读者了解如何迁移 Newsletter 到 phplist,并提供了一些美化的建议。
【由 Chat LangChain 生成】
本文作者:草梅友仁
本文地址: https://blog.cmyr.ltd/archives/92ad8b7d.html
版权声明:转载请注明出处!