Хорошо, форма отправляется с вложениями! Есть только одна маленькая вещь, я надеюсь, что кто-то может помочь мне с этим .. подробнее об этом позже. Сначала код.
В contact.js - мне пришлось изменить data: $(this).serialize(),
на data: new FormData(this),
$(function () {
$('#contact-form').validator();
$('#contact-form').on('submit', function (e) {
if (!e.isDefaultPrevented()) {
var url = "send.php";
$.ajax({
type: "POST",
url: url,
data: new FormData(this),
cache : false,
contentType : false,
processData : false,
success: function (data)
{
var messageAlert = 'alert-' + data.type;
var messageText = data.message;
var alertBox = '<div class="alert ' + messageAlert + ' alert-dismissable"><button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>' + messageText + '</div>';
if (messageAlert && messageText) {
$('#contact-form').find('.messages').html(alertBox);
$('#contact-form')[0].reset(); //Remove this line if form should not reset after submit
$('body, html').animate({scrollTop:$('#contact-form').offset().top}, 'fast'); //Remove this line if form should not scroll to top of the form after submit
}
}
});
return false;
}
})
});
Myform.html - 2 вещи: это enctype="multipart/form-data"
в <form>
и это
<!--attachments-->
<div class="form-group">
<label for="attachment">Attachment</label>
<input type="file" class="form-control-file" name="attachmentFile" id="attachmentFile">
</div>
где вы хотите в форме.
Наконец, поместите это в файл phpmailer:
//Add attachment
if(is_array($_FILES)) {
$mail->AddAttachment($_FILES['attachmentFile']['tmp_name'],$_FILES['attachmentFile']['name']);
}
Я сделал это ниже $mail->AddAddress($mailTo, $mailTo);
Пока как это исправить. Осталась еще одна проблема, о которой я говорил в начале.
Без data: new FormData(this),
Я все еще получаю свое okMessage (с разметкой), когда нажимаю кнопку Отправить, и форма остается на той же странице.
С data: new FormData(this),
он переходит на новую страницу и просто выделяет черный на белом простой текст (без разметки).
Так что как FormData что-то перекрывает. Надеюсь, кто-то может помочь мне с этим.
РЕДАКТИРОВАТЬ: Кажется, я тоже это исправил. Поместите это ..
cache : false,
contentType : false,
processData : false,
.. ниже data: new FormData(this),