2017-01-24 11 views
0

Ich versuche, mein Kontaktformular senden Sie die ausgewählte Option aus dem Auswahlmenü. Alle eingegebenen Daten senden (Name, Telefon, E-Mail, Vorort, Postleitzahl), aber nur nicht die Auswahloption (Status). Das php_errorlog gibt nichts von dem wieder, was ich sehen kann.PHP Kontaktformular nicht 'selectpicker' Daten senden

Ich bin neu in PHP, also bitte gehen Sie einfach auf mich.

Hier ist die Javascript und HTML

$(function() { 
 

 
    $("input,textarea").jqBootstrapValidation({ 
 
     preventSubmit: true, 
 
     submitError: function($form, event, errors) { 
 
      // additional error messages or events 
 
     }, 
 
     submitSuccess: function($form, event) { 
 
      // Prevent spam click and default submit behaviour 
 
      $("#btnSubmit").attr("disabled", true); 
 
      event.preventDefault(); 
 
      
 
      // get values from FORM 
 
      var name = $("input#name").val(); 
 
      var email = $("input#email").val(); 
 
      var phone = $("input#phone").val(); 
 
      var suburb = $("input#suburb").val(); 
 
      var state = $("input#state").val(); 
 
      var postcode = $("input#postcode").val(); 
 
      var message = $("textarea#message").val(); 
 
      var firstName = name; // For Success/Failure Message 
 
      // Check for white space in name for Success/Fail message 
 
      if (firstName.indexOf(' ') >= 0) { 
 
       firstName = name.split(' ').slice(0, -1).join(' '); 
 
      } 
 
      $.ajax({ 
 
       url: "././mail/contact_me.php", 
 
       type: "GET", 
 
       data: { 
 
        name: name, 
 
        phone: phone, 
 
        email: email, 
 
        suburb: suburb, 
 
        state: state, 
 
        postcode: postcode, 
 
        message: message 
 
       }, 
 
       cache: false, 
 
       success: function() { 
 
        // Enable button & show success message 
 
        $("#btnSubmit").attr("disabled", false); 
 
        $('#success').html("<div class='alert alert-success'>"); 
 
        $('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;") 
 
         .append("</button>"); 
 
        $('#success > .alert-success') 
 
         .append("<strong>Your message has been sent. </strong>"); 
 
        $('#success > .alert-success') 
 
         .append('</div>'); 
 

 
        //clear all fields 
 
        $('#contactForm').trigger("reset"); 
 
       }, 
 
       error: function() { 
 
        // Fail message 
 
        $('#success').html("<div class='alert alert-danger'>"); 
 
        $('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;") 
 
         .append("</button>"); 
 
        $('#success > .alert-danger').append("<strong>Sorry " + firstName + ", it seems that my mail server is not responding. Please try again later!"); 
 
        $('#success > .alert-danger').append('</div>'); 
 
        //clear all fields 
 
        $('#contactForm').trigger("reset"); 
 
       }, 
 
      }) 
 
     }, 
 
     filter: function() { 
 
      return $(this).is(":visible"); 
 
     }, 
 
    }); 
 

 
    $("a[data-toggle=\"tab\"]").click(function(e) { 
 
     e.preventDefault(); 
 
     $(this).tab("show"); 
 
    }); 
 
}); 
 

 
// When clicking on Full hide fail/success boxes 
 
$('#name').focus(function() { 
 
    $('#success').html(''); 
 
});
<form name="sentMessage" id="contactForm" novalidate> 
 
         <div class="row"> 
 
          <div class="col-md-6"> 
 
           
 
           <div class="form-group"> 
 
            <input type="name" class="form-control" placeholder="Your Name *" name="name" id="name" required data-validation-required-message="Please enter your name."> 
 
            <p class="help-block text-danger"></p> 
 
           </div> 
 
           
 
           <div class="form-group"> 
 
            <input type="phone" class="form-control" placeholder="Your Phone Number *" name="phone" id="phone" required data-validation-required-message="Please enter your phone number."> 
 
            <p class="help-block text-danger"></p> 
 
           </div> 
 
           
 
           <div class="form-group"> 
 
            <input type="email" class="form-control" placeholder="Your Email *" name="email" id="email" required data-validation-required-message="Please enter your email address."> 
 
            <p class="help-block text-danger"></p> 
 
           </div> 
 
           
 
            <div class="form-group"> 
 
            <input type="text" class="form-control" name="suburb" placeholder="Your Suburb *" id="suburb" required data-validation-required-message="Please enter your address."> 
 
            <p class="help-block text-danger"></p> 
 
           </div> 
 
           
 
           <div class="select"> 
 
           <div class="col-sm-6"> 
 
           <div class="form-group"> 
 
    \t \t \t \t <select class="selectpicker" name="state" id="state" data-width="100%" data-height="100%" title="Choose State *" data-style="btn-primary"> \t \t \t \t 
 
     \t \t \t \t \t <option value="QLD">QLD</option> 
 
     \t \t \t \t \t <option value="NSW">NSW</option> 
 
    \t \t \t \t </select> 
 
\t \t \t \t </div>  
 
\t \t \t  </div> 
 
\t \t \t  </div> 
 
           
 
           <div class="right-form-column"> 
 
           <div class="col-sm-6"> 
 
           <div class="form-group"> 
 
            <input type="number" class="form-control" name="postcode" placeholder="Post Code *" id="postcode" required data-validation-required-message="Please enter your post code."> 
 
            <p class="help-block text-danger"></p> 
 
           </div>            
 
           \t </div> 
 
\t \t \t  </div>                       
 
\t \t \t  </div> 
 
          
 
           <div class="col-md-6"> 
 
\t \t \t  <div class="select"> 
 
           <div class="col-xs-6"> 
 
           <div class="form-group"> 
 
</form>

Hier ist die PHP

<?php 
 
// check if fields passed are empty 
 
if(empty($_GET['name'])  || 
 
    empty($_GET['phone'])  || 
 
    empty($_GET['email'])  || 
 
    empty($_GET['suburb'])  || 
 
    empty($_GET['state'])  || 
 
    empty($_GET['postcode'])  || 
 
    empty($_GET['message']) || 
 
    !filter_var($_GET['email'],FILTER_VALIDATE_EMAIL)) 
 
    { 
 
    echo "No arguments Provided!"; 
 
    return false; 
 
    } 
 
    
 
$name = $_GET['name']; 
 
$phone = $_GET['phone']; 
 
$email_address = $_GET['email']; 
 
$suburb = $_GET['suburb']; 
 
$state = $_GET['state']; 
 
$postcode = $_GET['postcode']; 
 
$message = $_GET['message']; 
 

 
// create email body and send it  
 
$to = '[email protected]'; // PUT YOUR EMAIL ADDRESS HERE 
 
$email_subject = "P Services Contact Form: $name"; // EDIT THE EMAIL SUBJECT LINE HERE 
 
$email_body = "You have received a new message. \n\n".     
 
        " Here are the details:\n \nName: $name \n ".     
 
        "Email: $email_address\n Suburb: $suburb\n State: $state\n Post Code: $postcode\n Message \n $message"; 
 
$headers = "From: [email protected]\n"; 
 
$headers .= "Reply-To: $email_address"; 
 
if(mail($to,$email_subject,$email_body,$headers)){ 
 
echo "Mail sent successfully."; 
 
} 
 
else{ echo "Error."; 
 
}   
 
?>

Antwort

1

Es funktioniert nicht, weil y Sie haben $ ('input # state') verwendet.

Stattdessen versuchen

$('select#state').val(); 

oder einfach

$('#state').val(); 

Für ausgewählte Picker

$('selectpicker#state').val(); 
+0

Dank im Nachhinein ziemlich offensichtlich zu sein scheint. Ich musste auch die Select-Klasse wechseln, von "selectpicker" auf "select". Das einzige Problem ist, dass das styling selectpicker hat mich entfernt. Gibt es einen einfachen Weg, wie ich es wieder einbauen kann? – lmach8

+0

Ich verstehe es nicht? Sie funktionieren nur, wenn Sie die Selectpicker-Klasse entfernen? –

+0

Ja, aber ich habe es herausgefunden. Dies scheint zu funktionieren: '$ ('selectpicker # state'). Val();' Nicht sicher, warum ich das vorher nicht versucht habe. Danke, dass Sie mich in die richtige Richtung weisen. – lmach8

Verwandte Themen