邮件发送,正文内容格式h5,模板字符串拼接使用及赋值,原生js

2023-05-16

一、邮件发送
需求不难,传指定的参数给后端,调接口就直接发送了
就是参数里有个正文部分,一定要用h5写

写vue写习惯了,原生的都快忘光了,走了些弯路

二、h5
在页面上有个邮件发送的按钮,点击按钮打开弹窗,是一个仿邮箱发送的界面,类似如下:

在这里插入图片描述
红圈圈起来的部分都要用h5写
也就是说在vue这个单文件里,模板区可以正常用element画,但是给后端的得是h5

我自己是保持一致,两边都是一样的,也方便直接复用

三、模板字符串的处理

正文里有个表格,这个也不难画,div排列布局就可以了
主要说的是如何循环处理数据,以及input如何绑值,以及拼接

在确认发送这个按钮里处理数据
先定义个变量,用来处理循环出来的字符串,数组可以是后端给的 ,也可以是自己定义的,我这里因为表格的字段名都是固定的,所以我写死了,可以参考下,因为列表是一行四格,即a,a的值,b,b的值

模板字符串里有${}包裹的才是变量,不然都是字段串
所以要这样写才行 ${item.leftname}

    this.emailTable = [
        {
          leftname: 'A字段',
          rightname: 'B字段',
          leftValue: this.form.A,
          rightValue: this.form.B,
        },
        {
          leftname: 'C字段',
          rightname: 'D字段',
          leftValue: this.form.C,
          rightValue: this.form.D,
        },
        ]
 var info = ''
   this.emailTable.forEach(function (item) {
        info += ` <div style="display: flex">
                  <div
                    style="
                      height: 30px;
                      width: 140px;
                      line-height: 30px;
                      border-right: 1px solid #333;
                      border-bottom: 1px solid #333;
                      border-left: 1px solid #333;
                    "
                  >
                    <span style="padding-left: 5px">${item.leftname}</span>
                  </div>
                  <div style="height: 30px; line-height: 30px; border-right: 1px solid #333; border-bottom: 1px solid #333">
                    <input
                      type="text"
                      value="${item.leftValue}"
                      style="width: 140px; border: none; outline: none; font-size: 18px; font-weight: 500"
                      autocomplete="off"
                    />
                  </div>
                  <div style="height: 30px; width: 140px; line-height: 30px; border-right: 1px solid #333; border-bottom: 1px solid #333">
                    <span style="padding-left: 5px">${item.rightname}</span>
                  </div>
                  <div style="height: 30px; line-height: 30px; border-bottom: 1px solid #333; border-right: 1px solid #333">
                    <input
                      type="text"
                      value="${item.rightValue}"
                      style="width: 280px; border: none; outline: none; font-size: 18px; font-weight: 500"
                      autocomplete="off"
                    />
                  </div>

                </div>`
      })

不管有多少要循环处理的数据,都像上面这个格式来就行
然后定义一个变量,将全部的内容以模板字符串的格式处理

  let body = ` 
      <div >
            <p>
              <span style="font-size: 18px; font-weight: 500">Dear</span>
              <input
                type="text"
                id="nickName"
               value="${this.form.nickname}"
                style="border: none; outline: none; font-size: 18px; font-weight: 500"
                autocomplete="off"
              />
            </p>

            <p style="font-size: 18px; font-weight: 500">tks</p>
            <div style="color: #333; width: 700px">
              <div style="height: 30px; text-align: center; line-height: 30px; border: 1px solid #333">
                <span style="font-size: 20px; font-weight: 700">Loading</span>
              </div>
              <div style="height: 30px; text-align: left; line-height: 30px; border: 1px solid #333; border-top: none">
                <span style="padding-left: 5px">To:</span>
              </div>
            ${info}                                                
            <div style="display: flex">
            ${containHead}
            </div>           
           ${containBody}
            </div>
            <p style="font-size: 18px; font-weight: 500">Thank you very much!</p>       
          </div>`

然后将body作为参数传到接口里,参数格式会是下面这样
在这里插入图片描述
然后邮件里收到的内容,如下:
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

邮件发送,正文内容格式h5,模板字符串拼接使用及赋值,原生js 的相关文章

随机推荐

  • BPMN2.0 任务-脚本任务

    描述 脚本任务 script task 是自动执行的活动 当流程执行到达脚本任务时 会执行相应的脚本 脚本任务用左上角有一个小 脚本 图标的标准BPMN 2 0任务 圆角矩形 表示 脚本任务使用script与scriptFormat元素定义
  • 最短路径问题——基于Dijkstra算法和Floyd算法的最短路径问题

    目录 1 算法介绍 xff08 1 xff09 Dijkstra Algorithm xff08 迪杰斯特拉算法 xff09 xff08 2 xff09 Floyd Algorithm xff08 佛洛依德算法 xff09 xff08 3
  • 2.1.2 进程的状态与转换

    目录 知识总览 1 三种基本状态 xff08 1 xff09 运行态 xff08 Running xff09 xff08 2 xff09 就绪态 xff08 Ready xff09 xff08 3 xff09 阻塞态 xff08 Waiti
  • 合并排序与快速排序算法

    文章目录 算法介绍代码实现1 合并排序2 快速排序 总结 算法介绍 合并排序与快速排序是排序算法中常用的两种排序算法 xff0c 合并排序把数据分为两段 xff0c 从两段中逐个选最小的元素移入新数据的末尾 xff1b 快速排序是在序列中挑
  • 2进制、8进制、10进制、16进制相互转换

    文章目录 介绍1 二进制转其他进制2 八进制转其他进制3 十进制转其他进制4 十六进制转其他进制总结 介绍 百度百科 xff1a 进制也就是进位计数制 xff0c 是人为定义的带进位的计数方法 xff08 有不带进位的计数方法 xff0c
  • Hadoop学习笔记--HBase相关操作指令

    文章目录 引言0 HBase的启动与停止1 创建表2 删除表3 表的其他操作3 1 修改表结构3 2 查看表结构3 3 显示所有用户定义的表3 4 查询表是否存在3 5 查询表是否可用3 6 查询表中记录数 4 插入数据4 1 插入单条数据
  • Hadoop学习笔记--MapReduce

    文章目录 引言1 经典案例分析 xff1a WordCount1 1 Map阶段 xff1a TokenizerMapper类1 2 Reduce阶段 xff1a IntSumReduce类1 3 Driver阶段 xff1a main x
  • Hadoop学习笔记--YARN

    文章目录 引言1 YARN的优势1 1 可扩展性 xff08 Scalability xff09 1 2 可用性 xff08 Availability xff09 1 3 利用率 xff08 Utilization xff09 1 4 多租
  • scala编程--计算级数&统计学生成绩

    目录 案例1 xff1a 计算级数1 1 案例要求1 2 实现代码 案例2 xff1a 统计学生成绩1 1 案例要求1 2 实现代码 总结 案例1 xff1a 计算级数 1 1 案例要求 级数计算函数实现较为简单 xff0c 这里不再赘述
  • RDD本地文件系统读入显示文件不存在fileNotExit

    问题 在从本地文件系统读入数据创建RDD时 xff0c 执行行动操作 xff0c 显示文件不存在 解决方案 从本地文件系统读入时 xff0c 需在所有节点的相同目录下存在该文件 xff0c 如读取文件在 file span class to
  • spark-shell报错:java.io.IOException: Failed to replace a bad datanode on the existing pipeline due to

    目录 问题报错信息原因解决方案 问题 spark shell在执行一段时间后报错 xff1a java io IOException Failed to replace a bad datanode on the existing pipe
  • DPDK-VPP 学习笔记-06 bond 链路聚合 LACP

    DPDK VPP 学习笔记 06 bond 链路聚合 LACP 本笔记主要测试VPP与交换机链路聚合配置 amp 状态 Switch HW CE6880NIC Mellanox CX5 链路聚合简介 以太网链路聚合 Eth Trunk 简称
  • 基于Linux的小项目-在线词典

    接触到的基于Linux的第一个实战小项目 xff0c 在众多大牛的协助下完美实现 在线词典功能的实现 1 用户的注册 2 用户登录 3 单词的查询 4 历史记录的查看 5 用户在登录后修改密码 头文件 span class token ma
  • 树莓派串口通信(C语言wiringPi库)

    串口通信 配置gpio串口wringPi库串口函数代码测试 配置gpio串口 开启gpio串口 输入命令sudo raspi config选择Interfacing找到serial并打开选择OK 树莓派包含两个串口 硬件串口 xff08 d
  • 滑模控制问题总结

    设计切换函数 滑模面S xff08 x xff09 线性 xff1a 滑模面参数确定方法 xff1a Hurwitz 保证多项式为Hurwitz xff0c 即特征值在左半平面 主要适用于速度和精度要求都不高的非线性系统 非线性 滑模变结构
  • ESP8266的测试

    实际测试esp8266 一 线路连接 工具 xff1a WIFI模块1个 xff0c 串口软件1个 xff0c usb转串口工具一个 xff0c 杜邦线若干 1 找到模块的相关资料 xff0c 按照说明连接引脚 先看一下原理图和引脚说明 x
  • 【bug】弹窗列表,每次打开数据回显的选中项不对,已解决

    一个小bug xff0c 还是记录下吧 弹窗列表 xff0c 勾选数据后回显到表单里 xff0c 再次打开要选中状态 其实就是调弹窗数据的时候 xff0c 处理下 获取列表数据 getsalesdata span class token p
  • 【bug】vue-screenfull全屏时页面高度未自适应,已解决

    这个bug花了我下午快3个小时的时间去查找原因以及半个小时左右的时间去解决 xff0c 花了这么多精力 xff0c 值得记录下来 xff0c 避免以后再踩坑 一 vue screenfull是一款插件 xff0c 算是比较常用的插件了 xf
  • vue+el-form,表单内实现@keyup上下左右箭头移动聚焦

    需求是年前提的 xff0c 因为不着急 xff0c 就一直搁置着 xff0c 放在最后弄 年前快放假的时候 xff0c 抽空搜了下 xff0c 在表单内实现上下箭头移动聚焦的没搜到 xff0c 倒是有在表格内如何实现的 xff0c 但没有细
  • 邮件发送,正文内容格式h5,模板字符串拼接使用及赋值,原生js

    一 邮件发送 需求不难 xff0c 传指定的参数给后端 xff0c 调接口就直接发送了 就是参数里有个正文部分 xff0c 一定要用h5写 写vue写习惯了 xff0c 原生的都快忘光了 xff0c 走了些弯路 二 h5 在页面上有个邮件发