Прошу помощи с формой обратной связи
Дорогие форумчане, прошу помощи.
Есть форма обратной связи (код ниже), все работает, но я добавил в нее еще одно поле " <input type="text" placeholder="Ваше сообщение" name="mesg" id="mesg" class="input_text"/>" и никак не могу понять, как его прописать в файле параметров и feedback.php, чтобы сообщение приходило вместе с этим полем. Сейчас мне приходит сообщение в следующем виде: Адрес моего сайта name : имя отправителя фидбэка phone: номер отправителя фидбэка *(вот от этих "name:" и "phone:" я бы тоже хотел избавиться) Мне необходимо получить следующий вид сообщения: Адрес моего сайта Имя отправителя фидбэка Номер отправителя фидбэка <br> Сообщение отправителя Я новичок, а тут какой-то странный код обратки :blink: , никак не могу понять что откуда берется и куда отправляется. Буду очень благодарен! Далее код:
<form method="post" id="form-feedback">
<input type="text" placeholder="Ваше имя" name="name" id="name" class="input_text"/>
<div id="bthrow_error_name"></div>
<input type="text" placeholder="Контактный телефон" name="phone" id="phone" class="input_text"/>
<div id="bthrow_error_phone"></div>
<input type="text" placeholder="Ваше сообщение" name="mesg" id="mesg" class="input_text"/>
<input class="button" type="submit" value="Отправить заявку" />
<div class="throw_error"></div>
</form>
Для нее есть следующие параметры:
$("#form-feedback").submit(function(event) {
if ($('#name').val() == "")
{
$('#bthrow_error_name').fadeIn(1000).html('Представьтесь, пожалуйста.');
}
else if
($('#phone').val() == "")
{
$('#bthrow_error_name').empty();
$('#bthrow_error_phone').fadeIn(1000).html('Как с Вами связаться?');
}
else
{
var postForm = {
'name' : $('#name').val(),
'phone' : $('#phone').val()
};
$.ajax({
type : 'POST',
url : 'feedback.php',
data : postForm,
dataType : 'json',
success : function(data)
{
if (!data.success)
{
if (data.errors.name)
{
$('.throw_error').fadeIn(1000).html(data.errors.name);
}
}
else
{
$('#form-feedback').fadeIn(1000).html('<p>' + data.posted + '</p>');
}
}
});
}
event.preventDefault();
});
А также
$(function() {
$('#popupbutton').fancybox({
'padding': 37,
'overlayOpacity': 0.87,
'overlayColor': '#fff',
'transitionIn': 'none',
'transitionOut': 'none',
'titlePosition': 'inside',
'centerOnScroll': true,
'maxWidth': 400,
'minHeight': 310
});
$('#phone').mask('0 (000) 000-00-00');
$("#form-feedback").submit(function(event) {
if ($('#name').val() == "")
{
$('#bthrow_error_name').fadeIn(1000).html('Представьтесь, пожалуйста.');
}
else if ($('#phone').val() == "")
{
$('#bthrow_error_name').empty();
$('#bthrow_error_phone').fadeIn(1000).html('Как с Вами связаться?');
}
else if ($('#mesg').val() == "")
{
$('#bthrow_error_name').empty();
}
else
{
var postForm = {
'name' : $('#name').val(),
'phone' : $('#phone').val()
'mesg' : $('#mesg').val()
};
$.ajax({
type : 'POST',
url : 'feedback.php',
data : postForm,
dataType : 'json',
success : function(data)
{
if (!data.success)
{
if (data.errors.name)
{
$('.throw_error').fadeIn(1000).html(data.errors.name);
}
}
else
{
$('#form-feedback').fadeIn(1000).html('<p>' + data.posted + '</p>');
}
}
});
}
event.preventDefault();
});
});
и php:
<?php
$errors = array();
$form_data = array();
if ($_POST['name'] == "")
{
$errors['name'] = 'Введите Ваше имя';
}
if ($_POST['phone'] == "")
{
$errors['name'] = 'Введите Ваш телефон';
}
if (!empty($errors))
{
$form_data['success'] = false;
$form_data['errors'] = $errors;
}
else
{
$message = "<h1>Заявка с сайта ".$_SERVER['HTTP_HOST']."</h1>";
foreach($_POST as $k => $v)
{
$message .= $k.": ".$v."<br />";
}
$headers = 'MIME-Version: 1.0' . "\r\n";
$headers .= 'Content-type: text/html; charset=utf8' . "\r\n";
if (mail('xdd24@yandex.ru', 'Заявка с сайта '.$_SERVER['HTTP_HOST'], $message, $headers))
{
$form_data['success'] = true;
$form_data['posted'] = 'Наши менеджеры свяжутся с Вами в ближайшее время';
}
else
{
$errors['name'] = 'Ошибка отправки письма';
}
}
echo json_encode($form_data);
?>
|
Зачем отправлять форму из двух обработчиков?
|
Цитата:
как тут должно быть? |
Цитата:
Строка 18, код 2 - $("#form-feedback").submit(function(event) ... отправка формы в плагине fancybox. |
Цитата:
|
А что именно подсказать? Добавляйте обработку на сервере и добавленного поля, оно будет под ключом $_POST['mesg'].
|
Цитата:
Я пытался добавлять так, но ничего не получалось И не вижу где тут убрать надписи "name" и "phone", которые приходят в сообщении |
Цитата:
я понимаю, что тут где-то две строчки всего лишь дописать надо, но не понимаю куда и какие |
В обработчике ancybox в строках 20-33 находятся условия такой проверки полей. Только нужно добавить же вывод сообщения и для поле mesg, если оно не заполнено, то тоже типа
$('#bthrow_error_mesg').fadeIn(1000).html('Заполните....');
в строку 33, и добавив в форму <div id="bthrow_error_mesg"></div> Ну и на сервере
if ($_POST['mesg'] == "")
{
$errors['mesg'] = 'Заполните ... ';
}
Только не понятно, зачем возвращать на клиента сообщения о не заполнении полей, если клиент и сам их с успехом формирует, достаточно возвращать наличие (признак) ошибки в поле. И так не проверяют if ($_POST['mesg'] == ""), так как пробел уже не равен пустой строке, но в тоже время это ничто. Нужно убирать крайние пробелы, и лишь затем проверять пустая ли строка:
$_POST = array_map('trim', $_POST);
//А теперь можно и
if ($_POST['name'] == "")
.....
|
Цитата:
Получается, так? Код: HTML: <h2>Обратная связь</h2> <div class="comment"></div> <form method="post" id="form-feedback" > <input type="text" placeholder="Ваше имя" name="name" id="name" class="input_text"/> <div id="bthrow_error_name"></div> <br> <input type="text" placeholder="Контактный телефон" name="phone" id="phone" class="input_text"/> <div id="bthrow_error_phone"></div> <input class="button submit_callback_button_1" type="submit" value="Отправить заявку" /> <div id="bthrow_error_mesg"></div> </form> <span class="under-form"></span> JS:
$('#phone').mask('0 (000) 000-00-00');
$("#form-feedback").submit(function(event) {
if ($('#name').val() == "")
{
$('#bthrow_error_name').fadeIn(1000).html('Представьтесь, пожалуйста.');
}
else if
($('#phone').val() == "")
{
$('#bthrow_error_name').empty();
$('#bthrow_error_phone').fadeIn(1000).html('Как с Вами связаться?');
}
else if
($('#mesg').val() =="")
{
$('#bthrow_error_mesg').fadeIn(1000).html('Пожалуйста, напишите сообщение');
}
else
{
var postForm = {
'name' : $('#name').val(),
'phone' : $('#phone').val()
'mesg' : $('#mesg').val()
};
$.ajax({
type : 'POST',
url : 'feedback.php',
data : postForm,
dataType : 'json',
success : function(data)
{
if (!data.success)
{
if (data.errors.name)
{
$('.throw_error').fadeIn(1000).html(data.errors.name);
}
}
else
{
$('#form-feedback').fadeIn(1000).html('<p>' + data.posted + '</p>');
}
}
});
}
event.preventDefault();
});
PHP:
<?php
$errors = array();
$form_data = array();
if ($_POST['name'] == "")
{
$errors['name'] = 'Введите Ваше имя';
}
if ($_POST['phone'] == "")
{
$errors['name'] = 'Введите Ваш телефон';
}
if ($_POST['mesg'] == "")
{
$errors['mesg'] = 'Пожалуйста, напишите сообщение';
}
if (!empty($errors))
{
$form_data['success'] = false;
$form_data['errors'] = $errors;
}
else
{
$message = "<h1>Заявка с сайта ".$_SERVER['HTTP_HOST']."</h1>";
foreach($_POST as $k => $v)
{
$message .= $k.": ".$v."<br />";
}
$headers = 'MIME-Version: 1.0' . "\r\n";
$headers .= 'Content-type: text/html; charset=utf8' . "\r\n";
if (mail('xdd24@yandex.ru', 'Заявка с сайта '.$_SERVER['HTTP_HOST'], $message, $headers))
{
$form_data['success'] = true;
$form_data['posted'] = 'Благодарим за обращение! Наши менеджеры свяжутся с Вами в ближайшее время';
}
else
{
$errors['name'] = 'Ошибка отправки письма';
}
}
echo json_encode($form_data);
?>
|
я тут в HTML напутал, вот это будет, так ведь?
<h2>Обратная связь</h2> <div class="comment"></div> <form method="post" id="form-feedback"> <input type="text" placeholder="Ваше имя" name="name" id="name" class="input_text"/> <div id="bthrow_error_name"></div> <input type="text" placeholder="Контактный телефон" name="phone" id="phone" class="input_text"/> <div id="bthrow_error_phone"></div> <input type="text" placeholder="Ваше сообщение" name="mesg" id="mesg" class="input_text"/> <div id="bthrow_error_mesg"></div> <input class="button" type="submit" value="Отправить заявку" /> <div class="throw_error"></div> </form> |
Ну я же написал, что перед тем как проверять на сервере, да и на клиенте тоже самое, пуста или нет строка, ее нужно очистить от крайних пробелов, вот так
$_POST = array_map('trim', $_POST); - это нужно добавить в php-код до строки 6, и только после этого проверка if ($_POST['name'] == "") и далее. Ну я же не буду переписывать весь ваш код, чтобы вам ответить по нему скакать приходится, еще и мне повторять. 'Представьтесь, пожалуйста.', 'Как с Вами связаться?', 'Пожалуйста, напишите сообщение' - собственно и достаточно чтобы дать понять пользователю, что поле не заполнено, слать еще с сервера более грозные сообщения нет смысла. Поля сообщений о незаполненных полях имеют id bthrow_error_phone, а значит серверу достаточно вернуть ключи полей в которые на заполнены, и тогда вывод будет следующим, заменить: строку 39 JS if ( на if (data.errors) а строку 41 на
$(data.errors.map(function(n) {
return '#bthrow_error_'+n;
})
.join(','))
.empty()
.fadeIn(1000)
.html('Заполните....');
Ну или оставьте как есть, то есть сервер возвращает сообщения ошибок, только вывод их должен быть в цикле, так как могут быть не заполнены все поля. Проверять на пустоту поле на клиенте нужно также убирая пробелы крайние:
if($.trim($('#phone').val()) == "") ...
PS. Кодировка указанная для почтового сообщения не затрагивает поле subject, и кому повезет, тот прочтет, а кому нет, получит не читаемое. Кодировать нужно это поле:
mail('xdd24@yandex.ru', '=?utf-8?b?' . base64_encode('Заявка с сайта '.$_SERVER['HTTP_HOST']) . '?=', $message, $headers)
|
Цитата:
но у меня почему то всё перестало работать буду разбираться запихнул форму в попап вчера - работала сегодня в другой попап - перестала... |
Зачем вы цитируете полностью то, что я пишу, вы думаете я страдаю склерозом? :)
Цитата:
Вот тут я пас - в какие попапы вы пихаете мне неведомо, где конкретно заменить строку я пишу, но многое это как можно было бы сделать, и если делать, то сперва надо понять как работает, иначе и не будет, если как есть впихнуть. Например, если не возвращает сервер сообщения об ошибках, и оно будет одно и тоже у не заполненных полей, и определяемое клиентом, как я написал, то нужно еще и управлять таким сообщением. Эти сообщения должны исчезать, если соответствующее поле получило фокус. При отправке формы и пустых полях клиент опять будет выводить сообщения, но которые у вас определены в условиях. |
в любом случае, спасибо большое за разъяснения
буду разбираться |
| Часовой пояс GMT +3, время: 11:06. |