JS:
/* ---------------------------------------------
Contact form
— */
$(document).ready(function(){
$("#submit_btn").click(function(){
//get input field values
var user_name = $('input[name=name]').val();
var user_email = $('input[name=email]').val();
var user_message = $('textarea[name=message]').val();
//simple validation at client's end
//we simply change border color to red if empty field using .css()
var proceed = true;
if (user_name == "") {
$('input[name=name]').css('border-color', '#e41919');
proceed = false;
}
if (user_email == "") {
$('input[name=email]').css('border-color', '#e41919');
proceed = false;
}
//everything looks good! proceed...
if (proceed) {
//data to be sent to server
post_data = {
'userName': user_name,
'userEmail': user_email,
'userMessage': user_message
};
//Ajax post data to server
$.post('contact_me.php', post_data, function(response){
//load json data from server and output message
if (response.type == 'error') {
output = '<div class=«error»>' + response.text + '</div>';
}
else {
//reset previously set border colors and hide all message on .keyup()
$("#contact_form input, #contact_form textarea").keyup(function(){
$("#contact_form input, #contact_form textarea").css('border-color', '');
$("#result").slideUp();
});
});
Дополнение автора от 28.06.15 16:20:23 <?php
if($_POST)
{
$to_Email = «79533330011@ya.ru»; //Replace with recipient email address
$subject = 'Message from my website'; //Subject line for emails
//check if its an ajax request, exit if not
if(!isset($_SERVER['HTTP_X_REQUESTED_WITH']) AND strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) != 'xmlhttprequest') {
//exit script outputting json data
$output = json_encode(
array(
'type'=>'error',
'text' => 'Request must come from Ajax'
));
die($output);
}
//check $_POST vars are set, exit if any missing
if(!isset($_POST[«userName»]) || !isset($_POST[«userEmail»]) || !isset($_POST[«userMessage»]))
{
$output = json_encode(array('type'=>'error', 'text' => 'Input fields are empty!'));
die($output);
}
//Sanitize input data using PHP filter_var().
$user_Name = filter_var($_POST[«userName»], FILTER_SANITIZE_STRING);
$user_Email = filter_var($_POST[«userEmail»], FILTER_SANITIZE_EMAIL);
$user_Message = filter_var($_POST[«userMessage»], FILTER_SANITIZE_STRING);
//additional php validation
if(strlen($user_Name)<4) // If length is less than 4 it will throw an HTTP error.
{
$output = json_encode(array('type'=>'error', 'text' => 'Name is too short or empty!'));
die($output);
}
if(!filter_var($user_Email, FILTER_VALIDATE_EMAIL)) //email validation
{
$output = json_encode(array('type'=>'error', 'text' => 'Please enter a valid email!'));
die($output);
}
if(strlen($user_Message)<5) //check emtpy message
{
$output = json_encode(array('type'=>'error', 'text' => 'Too short message! Please enter something.'));
die($output);
}
if(!$sentMail)
{
$output = json_encode(array('type'=>'error', 'text' => 'Could not send mail! Please check your PHP mail configuration.'));
die($output);
}else{
$output = json_encode(array('type'=>'message', 'text' => 'Hi '.$user_Name .'! Thank you for your email'));
die($output);
}
}
?>
Вот пхп контакт_ми. В нем что нужно изменить кроме адреса получателя? его я изменил.
Здравствуйте. Судя по коду, в contact_me.php будет сама отправка. Там и нужно будет прописать Ваш адрес, куда отправлять данные формы.
Добрый день. Меня заинтересовал ваш ответ "Здравствуйте. Судя по коду, в contact_me.php будет сама отправка. Там и нужно будет прописать Ваш ад..." на вопрос http://www.liveexpert.org/topic/view/1538270-u-menya-est-html-kod-i-est-js-shablon-sajta-chto-nuzhno-sdelat-chtobi-oni-zarabotali-html-vse-polya-neobhodimo-zapolnit-otpravit-soobshenie. Можно с вами обсудить этот ответ?