How Do I Send An Email When The Form Is Submitted By Using Ajax
Solution 2:
This code has been tested by me
Alot of modifications has been done to your code. More features added like when a message is successful or failed the respectives messages will fading out after some time via ajax.
okay here is what I have done. I am sending your data using ajax as you wanted via formData() method.
Your submit button is now modified below.
<input type="submit" value="Submit" class="orange_btn" name="elqFormSubmitBut"/>
Your ajax result div modified below thus removing php script on it
<div id="result"></div>
At your Server backend your result response has also be modified as per below
echo "<div id='fadebox'>Thank you for contacting us. We will reply you as soon as possible</div>";
You can see id having fadebox attributes. Thats what fades out result response via ajax post after sometime. You can increase or reduce the time in the ajax code.
I guess You will need to be online to test your script properly because of the mail
<html>
<head>
<title>PHP AJAX Image Upload</title>
<link href="styles.css" rel="stylesheet" type="text/css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script type="text/javascript">
$(document).ready(function (e) {
$("#elqForm").on('submit',(function(e) {
e.preventDefault();
$.ajax({
url: "buyback.php",
type: "POST",
data: new FormData(this),
contentType: false,
cache: false,
processData:false,
success: function(data)
{
$("#result").html(data);
$('#fadebox').delay(5000).fadeOut('slow');
},
error: function()
{
}
});
}));
});
</script>
</head>
<body>
<div class="mktoForm">
<form id="elqForm" action="buyback.php" method="post">
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718959"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Contact_First_Name"><strong>First Name</strong> *:</label>
<input type="text" required="required" id="Contact_First_Name" name="Contact_First_Name" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718960"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Contact_Last_Name"><strong>Last Name</strong> *:</label>
<input type="text" required="required" id="Contact_Last_Name" name="Contact_Last_Name" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718961"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Contact_Email"><strong>Business Email</strong> *:</label>
<input type="text" required="required" pattern="[+a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$" id="Contact_Email" name="Contact_Email" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718962"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Job_Responsibility"><strong>Job Title</strong> *:</label>
<input type="text" required="required" id="Job_Responsibility" name="Job_Responsibility" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718963"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Company_Name"><strong>Company Name</strong> *:</label>
<input type="text" required="required" id="Company_Name" name="Company_Name" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718964"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Company_Country"><strong>Country</strong> *:</label>
<input type="text" required="required" id="Company_Country" name="Company_Country" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718965"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Company_State_Province"><strong>City</strong> *:</label>
<input type="text" required="required" id="Company_State_Province" name="Company_State_Province" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718966"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Contact_Phone_Number"><strong>Business Phone Number</strong> *:</label>
<input type="text" required="required" id="Contact_Phone_Number" name="Contact_Phone_Number" autocomplete="off">
</div>
<div class="elqFormRow">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718966"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<label for="Number_Of_Employees"><strong>Number of Employees</strong> *:</label>
<select id="Number_Of_Employees" name="Number_Of_Employees">
<option value="bet10and49">Between 10 and 49</option>
<option value="bet50and99">Between 50 and 99</option>
<option value="bet100and199">Between 100 and 199</option>
<option value="ab200">Above 200</option>
</select>
</div>
<div class="elqFormRow text-center">
<div style="line-height:0px;font-size:0px;padding:0;margin:0;max-height:0px;"><a name="eiel1718967"><img src="x.gif" width="1" height="0" style="display:block; height:0px !important;" class="anchorlink_image" alt=""></a></div>
<div class="elqFormRow text-center">
<input type="submit" value="Submit" class="orange_btn" name="elqFormSubmitBut"/>
</div>
</div>
</form>
<div id="result"></div>
</div>
</body>
</html>
here is the modified buyback.php. you can also see how the result response is modified and I just does validate using first_name
<?php
// validate using first name
if ($_POST['Contact_First_Name']) {
$Contact_First_Name = $_POST['Contact_First_Name'];
$Contact_Last_Name = $_POST['Contact_Last_Name'];
$Contact_Email = $_POST['Contact_Email'];
$Job_Responsibility = $_POST['Job_Responsibility'];
$Company_Name = $_POST['Company_Name'];
$Company_Country = $_POST['Company_Country'];
$Company_State_Province = $_POST['Company_State_Province'];
$Contact_Phone_Number = $_POST['Contact_Phone_Number'];
$Number_Of_Employees = $_POST['Number_Of_Employees'];
$to = "aaa@gmail.com";
$from = "bbb@gmail.com";
switch ($Number_Of_Employees) {
case "bet10and49": $Number_Of_Employees = "Between 10 and 49"; break;
case "bet50and99": $Number_Of_Employees = "Between 50 and 99"; break;
case "bet100and199": $Number_Of_Employees = "Between 100 and 199"; break;
case "ab200": $Number_Of_Employees = "Above 200"; break;
}
$message = "
Contact First Name: $Contact_First_Name<br/>
Contact Last Name: $Contact_Last_Name<br/>
Contact Email: $Contact_Email<br/>
Job Responsibility: $Job_Responsibility<br/>
Company Name: $Company_Name<br/>
City: $Company_State_Province<br/>
Business Phone Number: $Contact_Phone_Number<br/>
Number Of Employees: $Number_Of_Employees";
$subject = "New Message from the Buyback Form";
$header = 'MIME-Version: 1.0' . "\r\n";
$header .= 'Content-type: text/html; charset=utf-8' . "\r\n";
$header .= 'From:'. $from . " \r\n";
if (mail($to, $subject, $message, $header)) {
$result = "";
echo "<div id='fadebox'>Thank you for contacting us. We will reply you as soon as possible</div>";
} else {
echo "<div id='fadebox'>Message Sending Failed, try again</div>";
}
}
?>
Post a Comment for "How Do I Send An Email When The Form Is Submitted By Using Ajax"