javascript 使用Email.js发送邮件所需的用户ID

nhn9ugyo  于 2022-12-28  发布在  Java
关注(0)|答案(2)|浏览(355)

所以我试图实现这个电子邮件功能到我的投资组合,我会在底部插入当前代码.然而,我一直收到一个错误消息,说用户ID是必需的

我去了网站,并寻找我的用户ID,根据一些文档,用户ID应该放在init()之后,但没有用户ID。我给支持部门发了电子邮件,他们说用户ID被公钥取代了。这是我最初在该空间中拥有的,但这是我收到的错误。
这是我当前尝试发送邮件时生成错误的代码

import React, { useState, useRef } from "react";
import emailjs from "emailjs-com";
import { init } from "@emailjs/browser";

import "./contact.css";
init("wcnCiEjf9yoZnUt0e");
export default function Contact() {
  const [name, setname] = useState("");

  const [email, setemail] = useState("");
  const form = useRef();
  const [message, setmessage] = useState("");
  const sendEmail = (e) => {
    e.preventDefault();
    // console.log(e);
    console.log(form.current);

    const templateparams = {
      from_name: name + " " + email,
      to_name: "tamaraandreawilburn@gmail.com",
      feedback: message,
    };
    emailjs.send("service_e0zkrad", "template_7qrzf2e", templateparams).then(
      function (response) {
        console.log("SUCCESS!", response.status, response.text);
      },
      function (error) {
        console.log("FAILED...", error);
      }
    );
  };

  return (
    <>
      <div>
        <div className="contact-me-card row">
          <div className="col-lg-6 col-md-5 col-sm-12 left-contact px-2 py-2">
            <span className="get-in-touch mx-4 my-5">Get in touch </span>

            <div className="py-5 d-flex justify-content-center">
              <lottie-player
                src="https://assets3.lottiefiles.com/packages/lf20_u25cckyh.json"
                background="transparent"
                speed="1"
                style={{ width: "300px" }}
                loop
                autoplay
              ></lottie-player>
            </div>
          </div>

          <div className="col-lg-6 col-md-5 col-sm-12 my-auto">
            <form
              ref={form}
              className="d-flex flex-column card-contact-right"
              onSubmit={sendEmail}
            >
              <div className="input-group my-3 d-flex flex-column">
                <label> Name </label>
                <input
                  value={name}
                  onChange={(e) => {
                    setname(e.target.value);
                  }}
                  type="text"
                  placeholder="enter your name"
                  className="input-groups"
                />
              </div>
              <div className="input-group my-3 d-flex flex-column">
                <label>Email </label>
                <input
                  value={email}
                  onChange={(e) => {
                    setemail(e.target.value);
                  }}
                  type="text"
                  placeholder="enter your Email"
                  className="input-groups"
                />
              </div>
              <div className="input-group my-3 d-flex flex-column">
                <label> Message </label>
                <textarea
                  value={message}
                  onChange={(e) => {
                    setmessage(e.target.value);
                  }}
                  type="text"
                  placeholder="enter your message"
                  className="input-groups"
                />
              </div>
              <div className="input-group my-3 d-flex flex-column">
                <input
                  className="btn btn-success"
                  type="submit"
                  value="Send Message"
                />{" "}
              </div>
            </form>
          </div>
        </div>
      </div>
    </>
  );
}

任何帮助将不胜感激,因为我完全卡住了。

carvr3hs

carvr3hs1#

当调用emailjs.send()时,你需要添加你的public_key作为第四个参数。

emailjs.send("service_e0zkrad", "template_7qrzf2e", templateparams, <PUBLIC_KEY>).then(
      function (response) {
        console.log("SUCCESS!", response.status, response.text);
      },
      function (error) {
        console.log("FAILED...", error);
      }
    );

我在React应用程序上使用了这个方法,我在文档中找到了这个方法:https://www.emailjs.com/docs/examples/reactjs/

希望能有所帮助!

sdnqo3pr

sdnqo3pr2#

你可以试试这个解决方案。这个对我来说非常有效。你应该添加你的个人(PUBLIC_KEY),你可以在email.js(Account)选项中找到它。

emailjs.sendForm(
                'SERVICE_ID',
                'TEMPLATE_ID',
                form.current,
                'PUBLIC_KEY'
            )
            .then(
                (result) => {
                    alert('message sent successfully...');
                    console.log(result.text);
                },
                (error) => {
                    console.log(error.text);
                }
            );

相关问题