0

ajaxとphpを使用して画像をアップロードしています。私のコードはFirefoxで正常に機能しています。しかし、IEでは機能しません!

これが私のHTMLコードです。

<!doctype html>
<head>
<title>File Upload Progress Demo #1</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.js"></script>
<script src="http://malsup.github.com/jquery.form.js"></script>
<style>
body { padding: 30px }
</style>
</head>
<body>
    <h1>File Upload Progress Demo #1</h1>
        <form action="fileup.php" method="post" enctype="multipart/form-data">
        <input id="inp" type="file" name="uploadedfile" style="display:none"><br>
        <input id="btn" type="submit" value="Upload File to Server" style="display:none">
    </form>

    <div id="fileSelect" class="drop-area">Select some files</div>

<script>
(function() {

$('form').ajaxForm({

    complete: function(xhr) {
        alert(xhr.responseText);
    }
}); 

})();       


var fileSelect = document.getElementById("fileSelect"),
fileElem = document.getElementById("inp");


fileElem.addEventListener("change",function(e){
  document.getElementById('btn').click();
},false)  


fileSelect.addEventListener("click", function (e) {
  fileElem.click();
  e.preventDefault(); 
}, false);


</script>

</body>
</html>

これがphpコードです。

<?php
$target_path = "images/";

$target_path = $target_path . basename( $_FILES['uploadedfile']['name']); 

if(move_uploaded_file($_FILES['uploadedfile']['tmp_name'], $target_path)) {
    echo "The file ".  basename( $_FILES['uploadedfile']['name']). 
    " has been uploaded";
} else{
    echo "There was an error uploading the file, please try again!";
}
?>

Firefoxではファイルが完全にアップロードされ、アラートが表示されますが、IEでは何も起こりません。

4

1 に答える 1

3

フォームプラグインのサンプルページから

XMLHttpRequestレベル2をサポートするブラウザーは、ファイルをシームレスにアップロードできるようになります。

IEはXMLHttpRequestレベル2をサポートしていません。

編集:

プラグインはiframeフォールバックを使用しているため、Ajaxの問題ではないようです。javascriptコードをリファクタリングする必要があるかもしれません

$(function(){
    $('form').ajaxForm({
        complete: function(xhr) {
            alert(xhr.responseText);
        }
    }); 

    $('#inp').change(function(e) {
        $('#btn').click();
    });
});

ただし、補足として、ファイルドロップはIEでも使用できません。したがって、IEでファイルを手動で選択した場合にのみ機能します。また、隠しファイルを選択すると、ユーザーはファイルを選択できなくなります。ファイル入力でjavascriptからクリックイベントを発生させることもできません。透過的なファイル入力を使用する必要があります。

于 2012-08-06T11:25:42.830 に答える