首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >文本区域和选择器选项未发送到电子邮件

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

Stack Overflow用户
提问于 2016-04-14 01:36:47
回答 2查看 89关注 0票数 1

我已经按建议进行了搜索,但没有发现为什么我的表单版本不起作用。我有一个表单,收集姓名,电子邮件,电话,选择选项和信息在文本区域输入。我根据在select输入中选择的用户选项更改textarea和action php。

我使用PHP给表单内容发送电子邮件。我得到所有字段,除了:-消息/评论

代码语言:javascript
复制
<!-- 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 (显示/隐藏文本区域和显示/隐藏文件上载对话框)

代码语言:javascript
复制
$(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 (用于其中一个操作)

代码语言:javascript
复制
<?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' ) ;
    }
?>

因此,除了消息/评论文本的之外,我获得了所有字段

如果你想看看我在电子邮件单击此处里得到了什么

如果您单击,您会看到当我提交一个HR/职业> IT + Upload File + Message...The消息时我得到了什么。

提前谢谢你的帮助。

VS

EN

回答 2

Stack Overflow用户

发布于 2016-04-14 03:12:24

您需要给您的复选框一个名称,而不是选项。

你有

代码语言:javascript
复制
<select id="interest" class="selector-career form-control" required>

它必须是

代码语言:javascript
复制
<select name="interest" id="interest" class="selector-career form-control" required>

关于文件附件,您应该检查上传的文件,好吗?

代码语言:javascript
复制
if (isset($_FILES['resume']) &&
    $_FILES['resume']['error'] == UPLOAD_ERR_OK) {
    $mail->AddAttachment($_FILES['resume']['tmp_name'],
                         $_FILES['resume']['name']);
}
票数 0
EN

Stack Overflow用户

发布于 2016-04-14 22:29:29

这就是我在div /表单包装器中使用的选择器。

您需要选择选项的索引,而不是选项容器。

这是为了选择国家,为了节省空间,我移走了其中大部分国家。查看它的结构并修改您的代码。

请注意对客户端选择的选项进行索引的方括号。"state_sel“是包含所选项的变量。我漏掉了一个函数调用的按钮。

代码语言:javascript
复制
 <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>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36612360

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档