Ich habe ein sehr einfaches HTML-Formular. Das Formular ist mit einer PHP-Datei verbunden und sendet die Ergebnisse per E-Mail an mich. Aber ich habe ein Problem mit Radiobuttons. Unabhängig davon, welches Optionsfeld der Benutzer auswählt, sagt die E-Mail immer, dass der Benutzer das erste Optionsfeld ausgewählt hat.Mein Formular sendet immer die erste Option
Ich habe einige Nachforschungen gemacht und ich denke, ich muss schreiben "echo $ gender;" in der PHP-Datei irgendwo. Ich habe es versucht und Dreamweaver markiert es immer als Syntaxfehler.
ist hier der wesentliche Code:
HTML:
<form>
<input type="radio" name="gender" id="gender" value="female" /> Female<br>
<input type="radio" name="gender" id="gender" value="male" checked /> Male<br>
</form>
Javascript:
$(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 gender = $("input#gender").val();
$.ajax({
url: "././mail/contact_me.php",
type: "POST",
data: {gender: gender},
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'>×")
.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'>×")
.append("</button>");
$('#success > .alert-danger').append("<strong>Sorry, 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");
});
});
PHP:
<?php
$gender = $_POST['gender'];
// Create the email and send the message
$to = '[email protected]';
$email_subject = "New message from contact form";
$email_body = "Gender: $gender \n\nPress 'reply' to respond to the sender.";
$headers = "From: [email protected]\n";
return true;
?>
Nun .. Sie verwenden jQuery-Syntax gibt, nicht PHP ... Bitte mehr Code schreiben. Und warum sollten Sie $ room_type schreiben? Was enthält das? Das Geschlecht? Ich bin verwirrt: p – entiendoNull
Sorry, mein Fehler. Ich wollte dort "Geschlecht" eingeben, nicht "room_type". –
Und wie senden Sie dieses Formular ein? Von AJAX? Das 'var gender = $ (" input # gender "). Val();' ist nicht PHP - es ist JavaScript (jQuery). Wie sieht dein PHP-Skript aus? – entiendoNull