基本的に、フォームの送信時にajaxで画像ファイルを渡し、画像を取得して、添付ファイルとして電子メールで送信します。
formは次のとおりです。
<form role="form" action="" name="devis" id="devis" method="post" enctype="multipart/form-data" class="form-horizontal">
<fieldset>
<div class="form-group">
<label class="control-label col-md-4" for="societe">Company</label>
<div class="col-md-8">
<input type="text" class="form-control input-md col-md-8" name="societe" value="" maxlength="" id="societe">
</div>
</div>
<div class="form-group">
<label class="control-label col-md-4" for="message"><span class="required">* </span>Message</label>
<div class="col-md-8">
<textarea rows="5" name="message" class="form-control input-md col-md-8" maxlength="" required="" style="resize:none;" id="message"></textarea>
</div>
</div>
<div class="form-group" id="input_file">
<label class="control-label col-md-4" for="image_input_field">Logo</label>
<div class="col-md-8">
<div class="input-group uploaddiv">
<span class="input-group-btn">
<span class="btn btn-default btn-file">
Parcourir <input type="file" id="image_input_field" name="file">
</span>
</span>
<input type="text" class="form-control" readonly="">
</div>
</div>
</div>
<div class="form-group">
<div class="form-actions col-md-9 col-md-offset-3 text-right">
<input type="submit" value="Envoyer" name="" class="btn btn-primary" id="submit">
<input type="reset" value="Annuler" name="" class="btn btn-default" id="reset">
</div>
</div>
</fieldset>
</form>
私のコードのエラーを見つけることができないようです! AJAX callは次のとおりです。
jQuery(document).on("click", "#submit", function(e) {
e.preventDefault();
var fileInput = document.getElementById('image_input_field');
var file = fileInput.files[0];
var formData = new FormData();
formData.append('file', file);
// console.log(file);
var societe = $("input#societe").val();
var message = $("textarea#message").val();
jQuery.ajax({
url: "ajax.php",
type: "post",
data: {
'file': file,
'module' : 'ajax_data_form',
'societe': societe,
'message': message
},
cache: false,
success: function(reponse) {
if(reponse) {
alert(reponse);
// console.log(reponse);
// jQuery('#devis').trigger("reset");
} else {
alert('Erreur');
}
}
});
});
そして、これがajax.phpです:
<?php
if( isset($_POST['module']) && $_POST['module'] == "ajax_data_form" )
{
var_dump($_FILES);
}
$.ajax({
type: "POST",
url: pathname,
data: new FormData($('#devis')[0]),
processData: false,
contentType: false,
success: function (data) {
$("#divider").html(data);
}
});
$_FILES[];
で通常どおりファイルデータを取得します
試してもらえますか
<script type="text/javascript">
$(document).ready(function() {
$("#submit").click(function() {
var fileInput = document.getElementById('image_input_field');
var file = fileInput.files[0];
var formData = new FormData();
formData.append('file', file);
// console.log(file);
var societe = $("input#societe").val();
var message = $("textarea#message").val();
$.ajax({
url: "ajax.php",
type: "POST",
data: "file="+file,
cache: false,
success: function(reponse) {
if(reponse) {
alert(reponse);
// console.log(reponse);
// $('#devis').trigger("reset");
} else {
alert('Erreur');
}
}
});
}); });
</script>
Ajax.phpで
書くだけ
echo 'something';
すでにご存知かもしれませんが、ajax呼び出しを介してファイルのアップロードを処理することはできません。一度 HTML5 FILE I/O API が準備でき、主要なブラウザーで実装されると可能になります。
JQuery iframe投稿フォームプラグインを使用してiframeにデータを投稿できるため、ユーザーエクスペリエンスはajax呼び出し(ページの部分更新)に似ています。
リンクは次のとおりです。 https://github.com/dogzworld/iframe-post-form
説明:「このjQuery ajaxアップロードプラグインは非表示のiframeを作成し、フォームのターゲット属性を設定してそのiframeに投稿します。フォームが送信されると、非表示のiframeに投稿されますiframeからのサーバーの応答。」
前述のように、サーバーから応答を送信し、それに応じてWebページに更新を表示できます。デモページが必要ですが、現時点では機能していません。
ファイルのアップロードにも使用できます。
呼び出し例:
jQuery('#frmId').iframePostForm({
json : true,
post : function () {
//return true or false
return true;
},
complete : function (response) {
//complete event
console.log(response);
}
});
Jquery Formプラグインと呼ばれるJqueryプラグインの使用 リンク
Jqueryを使用してフォームを送信することをお勧めします。非表示フィールドに保持できるデータは何でも必要です。
$("#devis").ajaxSubmit(options);
return false;
このようなPHPページでファイルを簡単に取得できます
$ImageTempname = $_FILES['ImageFile']['tmp_name'];
$ImageFilename = $_FILES['ImageFile']['name'];
$ImageType = $_FILES['ImageFile']['type'];
等々.....