繁体   English   中英

textarea和选择器选项未发送到电子邮件

[英]textarea and selector option not being sent to email

我按照建议进行了搜索,但没有找到为什么我的表单版本不起作用。 我有一个表单,收集名称,电子邮件,电话,选择选项和textarea输入中的消息。 我根据select输入中选择的用户选项更改textarea和action php。

我使用PHP通过电子邮件发送表单内容。 我得到除了以下所有字段:-Message / Comments

HTML

<!-- Career Form -->
<form id="careerContactForm" role="form" action="" method="post" enctype="multipart/form-data">
  <!-- $name -->
  <div class="row form-group">
    <div class="col-md-8 col-md-offset-2 required">
      <label for="contact-name">Full Name</label>
      <input type="text" name="name" class="form-control" id="contact-name" placeholder="Full Name" required>
    </div>
  </div>
  <!-- $email -->
  <div class="row form-group">
    <div class="col-md-4 col-md-offset-2 required">
      <label for="contact-email">Email</label>
      <input type="text" name="email" class="form-control" id="contact-email" placeholder="Email" required>
    </div>
    <!-- $phone -->
    <div class="col-md-4 required">
      <label for="contact-phone">Phone Number</label><br />
      <input type="text" class="form-control bfh-phone" data-country="US" id="contact-phone" name="phone" placeholder="Phone Number" required>
    </div>
  </div>
  <!-- $who -->
  <div class="row form-group">
    <div class="col-md-8 col-md-offset-2 required select-wrapper">
    <!-- Contact -->
      <label for="contact-who">Who are you trying to contact?</label>
      <select class="selectorWho form-control" name="who" required>
        <option value="None"><em>--Please Select One--</em></option>
        <option value="general">General</option>
        <option value="HR / Careers">HR / Careers</option>
        <option value="sales">Sales</option>
        <option value="td">TDXperts</option>
        <option value="Other">Other</option>
      </select>
    </div>
  </div>
  <!-- $interest -->
  <div class="row form-group hidden uploadResume">
    <div class="col-md-8 col-md-offset-2 required select-wrapper">
     <!-- Career -->
      <label>I'm looking for employment opportunities in…</label>
      <select class="selector-career form-control" name="interest" required>
        <option value="None"><em>--Please Select One--</em></option>
        <option value="Accounting">Accounting</option>
        <option value="Administration">Administration</option>
        <option value="Finance">Finance</option>
        <option value="general">General</option>
        <option value="HR">HR</option>
        <option value="IT">IT</option>
        <option value="Logistics & Customs Affairs">Logistics & Customs Affairs</option>
        <option value="Marketing">Marketing</option>
        <option value="Purchasing">Purchasing</option>
        <option value="Sales">Sales</option>
        <option value="Supply Chain Planning">Supply Chain Planning</option>
        <option value="Warehouse">Warehouse</option>
        <option value="Other">Other</option>
      </select>
    </div>
    <div class="col-md-8 col-md-offset-2 required">
      <label for="uploadResume">Upload Your Resume</label>
      <input type="file" name="resume" id="resume-upload">
      <p class="help-block"><em>You must choose a valid file. We accept .doc, .docx, .pdf, .rtf and .txt files</em></p>
    </div>
  </div>
  <!-- Career Submit: hide / show -->
  <div class="row form-group">
    <div class="col-md-8 col-md-offset-2 hidden careerContact">
      <!-- Contact -->
      <label for="contact-message">Questions or Comments</label>
      <textarea name="message" cols="50" rows="6" id="contact-message" class="form-control" placeholder="Would you like to include any more information?" ></textarea>
    </div>
    <div class="col-md-8 col-md-offset-2 hidden contactMessage">
      <!-- Career -->
      <label for="career-message">Message</label>
      <textarea name="comments" cols="50" rows="6" id="career-message" class="form-control" placeholder="Your message..." ></textarea>
    </div>
  </div>
  <div class="row form-group">
    <div class="col-md-8 col-md-offset-2">
      <button type="submit" class="btn">Send message</button>
    </div>
  </div>
</form>

JS(显示/隐藏textareas和显示/隐藏文件上传对话框)

$(document).ready(function(e) {
$(".selectorWho").on('change', function(e) {
    e.preventDefault();
    var uploadResume = $('.uploadResume');
    var comments = $('.contactMessage');
    var careerComments = $('.careerContact');
    if (this.value == "HR / Careers") {
        uploadResume.slideDown().removeClass("hidden");
        careerComments.removeClass("hidden");
        comments.addClass("hidden");
        var action = "do/careers-submit.php";
        var submitButton = 'career-submit';
    } else {
        uploadResume.slideUp().addClass('hidden');
        careerComments.addClass('hidden');
        comments.removeClass("hidden");
        var action = "do/contact-submit.php";
        var submitButton = 'contact-submit';
    }
    $("#careerContactForm").attr("action", action);
});
});

PHP(用于其中一个操作)

<?php 
    require("../classes/class.phpmailer.php");
    $mail = new PHPMailer();

    $name = $_POST['name'];
    $email = $_POST['email'];
    $phone = $_POST['phone'];
    $who = $_POST['who'];
    $interest = $_POST['interest'];
    $comments = $_POST['comments'];

    $mail->IsSMTP();
    $mail->From     = "$email";
    $mail->FromName = "$name";
    // $mail->AddAddress("hr@tireco.com","Tireco HR");
    $mail->AddAddress("vs@tireco.com","Tireco HR");
    $mail->Subject  = "New Resume Submission";
    $mail->Body     = "Name:\n $name\n\n\nPhone:\n $phone\n\n\nEmail:\n $email\n\n\nContacting:\n $who\n\n\nInterested In:\n -$interest\n\n\nQuestions/Comments:\n $comments";

    if (isset($_FILES['resume']) &&
        $_FILES['resume']['error'] == UPLOAD_ERR_OK) {
        $mail->AddAttachment($_FILES['resume']['tmp_name'],
                         $_FILES['resume']['name']);
    }

    $mail->WordWrap = 50;

    if(!$mail->Send()) {
      echo 'Message was not sent.';
      echo 'Mailer error: ' . $mail->ErrorInfo;
    } else {
        header( 'Location: ../thankYou.html' ) ;
    }
?>

所以, 除了消息/注释textarea文本之外 ,我得到所有字段。

如果您想查看我在电子邮件中收到的内容, 请单击此处

如果你点击了,你看到我提交HR / Careers> IT +上传文件+消息时得到的结果 ......消息被省略。

预先感谢您的帮助。

VS

您需要为选择框指定名称,而不是选项。

你有

<select id="interest" class="selector-career form-control" required>

它需要

<select name="interest" id="interest" class="selector-career form-control" required>

关于文件附件,您应该检查上传的文件确定

if (isset($_FILES['resume']) &&
    $_FILES['resume']['error'] == UPLOAD_ERR_OK) {
    $mail->AddAttachment($_FILES['resume']['tmp_name'],
                         $_FILES['resume']['name']);
}

这是我用于我的选择器的东西,我在div / form包装器里面。
您需要选择选项的索引,而不是选项容器
这是为了选择状态,我为了节省空间而删除了最多的状态。 查看它的结构并修改您的代码。
注意索引客户选择的选项的方括号。 “state_sel”是包含所选项的变量。 我省略了一个函数调用按钮。

 <form id="state_opt" name="state_opt">&nbsp;State
<select id="state_mgr" onChange="state_sel=document.state_opt.state_mgr.options[document.state_opt.state_mgr.selectedIndex].value;">
<option selected value="0">None</option>
<option value="AL">Alabama
<option value="MT">Montana
<option value="WI">Wisconsin
<option value="MO">Missouri
<option value="WY">Wyoming
</select>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM