当前位置: 首页 > news >正文

自建导航站wordpress巨量算数数据分析入口

自建导航站wordpress,巨量算数数据分析入口,网站建设需要注册什么类型的公司,b2c模式的电商网站原文链接 CSDN 的排版/样式可能有问题,去我的博客查看原文系列吧,觉得有用的话, 给我的库点个star,关注一下吧 上一篇【Next.js 入门教程系列】07-身份验证 发送邮件 Setting Up React Email​ React Email 是一个高效便捷的 E…

原文链接

CSDN 的排版/样式可能有问题,去我的博客查看原文系列吧,觉得有用的话, 给我的库点个star,关注一下吧

上一篇【Next.js 入门教程系列】07-身份验证

发送邮件

Setting Up React Email

React Email 是一个高效便捷的 Email 库,包含多个组件,包括编写,发送等等功能。使用 npm i react-email @react-email/components 安装

安装好打开 package.json,在 scripts 中添加 "preview-email": "email dev -p 5051" script

"scripts": {"dev": "next dev -- -p 5050","build": "next build","start": "next start -- -p 5050","lint": "next lint",// Add this"preview-email": "email dev -p 5051"
},

Careate Email Template

本章代码链接

在根目录下(app 同级目录)创建 emails 文件夹,在其中创建 WelcomeTemplate.tsx。如下就是一个邮件的模板,会将输入用户的名字添加到其中

# emails/WelcomeTemplate.tsximport React from "react";
import {Html,Body,Container,Text,Link,Preview,
} from "@react-email/components";const WelcomeTemplate = ({ name }: { name: string }) => {return (<Html><Preview>Welcome aborad!</Preview><Body><Container><Text>Hello {name}</Text><Link href="http://dino.castamerego.com">www.dino.castamerego.com</Link></Container></Body></Html>);
};
export default WelcomeTemplate;

Preview Email

本章代码链接

首先在 .gitignore 中添加 .react-email,以防产生的大量文件污染 git。使用 npm preview-email 命令, 打开浏览器,访问对应端口(笔者设置的是 localhost:5051)即可看到

Preview Email

Style Email

本章代码链接

我们可以直接使用 CSS 来添加样式,也可以直接使用 Tailwind,这里把两种都给出

  • CSS
  • TailWind
# emails/WelcomTemplate.tsx// Use CSS
import React, { CSSProperties } from "react";
import {Html,Body,Container,Text,Link,Preview,
} from "@react-email/components";const WelcomeTemplate = ({ name }: { name: string }) => {return (<Html><Preview>Welcome aborad!</Preview><Body style={body}><Container><Text style={heading}>Hello {name}</Text><Link href="http://dino.castamerego.com">www.dino.castamerego.com</Link></Container></Body></Html>);
};const body: CSSProperties = {background: "#fff",
};const heading: CSSProperties = {fontSize: "32px",
};export default WelcomeTemplate;
# emails/WelcomTemplate.tsx// Use TailWind
import React, { CSSProperties } from "react";
import {Html,Body,Container,
// import TailwindTailwind,Text,Link,Preview,
} from "@react-email/components";const WelcomeTemplate = ({ name }: { name: string }) => {return (<Html><Preview>Welcome aborad!</Preview>{/* 将 Body 用 <Tailwind> 包起来*/}<Tailwind><Body className="bg-white"><Container><Text className="font-bold text-3xl">Hello {name}</Text><Link href="http://dino.castamerego.com">www.dino.castamerego.com</Link></Container></Body></Tailwind></Html>);
};export default WelcomeTemplate;

Sending Emails

本章代码链接

使用 npm i resend@1.0.0 安装 resend 用于发送邮件。进入Resend官网,注册账号,获取一个 API Key,并添加到 .env 中,设置 RESEND_API_KEY=... 即可。在 api/ 中添加 send-email/route.tsx,调用 resend.emails.send() 即可

# api/send-email/route.tsximport WelcomeTemplate from "@/emails/WelcomeTemplate";
import { NextResponse } from "next/server";
import { Resend } from "resend";const resend = new Resend(process.env.RESEND_API_KEY!);export async function POST() {await resend.emails.send({from: "...",to: "castamere@gmail.com",subject: "...",react: <WelcomeTemplate name="Castamere" />,});return NextResponse.json({});
}

下一篇讲优化技巧

下一篇【Next.js 入门教程系列】09-优化技巧

http://www.sczhlp.com/news/14755/

相关文章:

  • PKC7300 高频电流探头在开关电源瞬态测试中的应用方案
  • VGGT: Visual Geometry Grounded Transformer
  • 国产测试平台崛起:Gitee Test如何成为关键领域信创体系的质量守门人
  • 【总结】单调栈
  • 做网站南京搜索引擎调词软件
  • SFDA的网站建设是什么怎样做推广更有效
  • 做物流哪个网站货源多百度投放
  • 黄石网站建设推荐优化推广服务
  • 2003 您的安全设置不允许网站使用安装网站外链的优化方法
  • 做自己的批发网站需要什么营业执照怎么注册网站平台
  • 网站域名解析怎么做seo培训学什么
  • wordpress默认首页设置丽水百度seo
  • 曲靖市麒麟区建设局规划网站王通seo教程
  • 网站免费模板资源2345网址大全下载到桌面
  • 网上做任务赚钱网站有哪些百度网址大全简单版
  • 事倍功半是蠢蛋45 pycharm启动terminal 没有虚拟环境
  • gcd位运算写法
  • 代码存档_古地图电子化_平面二维点集之间的局部普氏重叠度计算及可视化
  • 网站建设与网站开发网站优化 seo和sem
  • 怎么做网站文件网络营销环境分析
  • 网站kv如何做网络公司网络推广
  • 建个网站有什么用重庆网站排名
  • vulnyx Ober writeup
  • 代码存档_古地图电子化_地物精度概率矩阵DAG
  • 网站做qq发送链接免费发外链
  • 做网站前端需要编程基础吗百度信息流开户多少钱
  • 国际实时新闻最新消息绍兴seo排名公司
  • 郑州网站制作推广杭州优化外包
  • 优质的设计网站有哪些企业管理培训课程
  • wordpress全球销量主题网络优化行业的发展前景