javascript - 文本区域和选择器选项未发送到电子邮件

标签 javascript php html forms textarea

我已按照建议进行搜索,但尚未找到为什么我的表单版本不起作用。我有一个表单,用于收集姓名、电子邮件、电话、选择选项和文本区域输入中的消息。我根据选择输入中选择的用户选项更改文本区域和操作 php。

我使用 PHP 通过电子邮件发送表单内容。我得到除以下之外的所有字段: -留言/评论

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(显示/隐藏文本区域和显示/隐藏文件上传对话框)

$(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' ) ;
    }
?>

因此,我获取了消息/评论文本区域文本除外的所有字段。

如果您想查看我在电子邮件 click here 中收到的内容

如果您点击,您会看到当我提交 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']);
}

关于javascript - 文本区域和选择器选项未发送到电子邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36612360/

相关文章:

php - 如果您的弹出窗口被阻止,如何获得通知?(HTML JS PHP)

javascript - 如何模拟 Jasmine 中其他服务方法中调用的 $http.post 方法?

javascript - PHP 日期验证功能

javascript - HTML 数据效果到 jQuery

javascript - HTML 和 CSS : same height two div in div

html - css:在没有不间断空格的情况下阻止单词流到另一行?

javascript - 如何防止按钮点击默认

php - URL/HTML 转义/编码

php - 如何使用 NOT IN 从多个表中删除行

php - codeigniter 从字符串修改数组以进行 insert_batch