Email JS: работает только иногда - PullRequest
0 голосов
/ 30 марта 2020

Я разрабатываю контактную форму, используя React и Email JS. Моя проблема в том, что, когда я ввожу свои собственные значения для имени, электронной почты, телефона или сообщения, электронная почта не работает. Когда я нажимаю кнопку «Отправить сообщение», не вводя ничего в «Имя», «Электронная почта», «Телефон» или «Сообщение» (поэтому используются значения по умолчанию), иногда это срабатывает (обычно не по первому нажатию кнопки, а по второму щелчку).

Я не уверен, как это исправить, и хотел бы помочь!


export default class Contact extends React.Component {
    constructor(props) {
        super(props);
        this.state = { message: '', name: 'Name', email: 'Email', phone: 'Phone' };
        this.handleChange = this.handleChange.bind(this);
        this.handleSubmit = this.handleSubmit.bind(this);
      }

      handleChange(event) {
        this.setState({
          [event.target.name]: event.target.value
        });
    }

      handleSubmit (event) {
        var template_params = {
            "name": "name_value",
            "message": "message_value",
            "phone": "phone_value",
            "email": "email_value"
         }

         var service_id = "default_service";
         var template_id = <TEMPLATE_ID_FROM_EMAILJS_ACCOUNT>;
         window.emailjs.send(service_id, template_id, template_params).then(res => {
             console.log('MESSAGE SENT', res.status);
             alert("Message Sent!");
         }).catch(e => {
             console.log("There was an error", e);
         }); 
      }

    render() {

        return (
            <section className="page-section" id="contact">
                <div className="container">
                <div className="row">
                    <div className="col-lg-12 text-center">
                    <h2 className="section-heading text-uppercase">Contact Us</h2>
                    <h3 className="section-subheading text-muted">Fill in the form below to contact us through email</h3>
                    </div>
                </div>
                <div className="row">
                    <div className="col-lg-12">
                    <form id="contactForm" name="sentMessage" noValidate="noValidate">
                        <div className="row">
                        <div className="col-md-6">
                            <div className="form-group">
                            <input className="form-control" id="name" name="name" type="text" placeholder="Your Name *" required="required" data-validation-required-message="Please enter your name." onChange={this.handleChange} value={this.state.name}></input>
                            <p className="help-block text-danger"></p>
                            </div>
                            <div className="form-group">
                            <input className="form-control" id="email" name="email" type="email" placeholder="Your Email *" required="required" data-validation-required-message="Please enter your email address." onChange={this.handleChange} value={this.state.email}></input>
                            <p className="help-block text-danger"></p>
                            </div>
                            <div className="form-group">
                            <input className="form-control" id="phone" name="phone" type="tel" placeholder="Your Phone *" required="required" data-validation-required-message="Please enter your phone number." onChange={this.handleChange} value={this.state.phone}></input>
                            <p className="help-block text-danger"></p>
                            </div>
                        </div>
                        <div className="col-md-6">
                            <div className="form-group">
                            <textarea className="form-control" id="message" name="message" placeholder="Your Message *" required="required" data-validation-required-message="Please enter a message." onChange={this.handleChange} value={this.state.message}></textarea>
                            <p className="help-block text-danger"></p>
                            </div>
                        </div>
                        <div className="clearfix"></div>
                        <div className="col-lg-12 text-center">
                            <div id="success"></div>
                            <button id="sendMessageButton" className="btn btn-primary btn-xl text-uppercase" type="submit" onClick={this.handleSubmit}>Send Message</button>
                        </div>
                        </div>
                    </form>
                    </div>
                </div>
                </div>
            </section>
        )
        }
}

1 Ответ

1 голос
/ 30 марта 2020

Не уверен насчет этого, но, похоже, вы не препятствуете поведению отправки по умолчанию, поэтому ваша страница обновляется, ваша форма новая, а ваша функция не вызывается. Попробуйте добавить

event.preventDefault();

в начале вашей функции handleSubmit.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...