Rumah > pembangunan bahagian belakang > tutorial php > Bagaimana untuk Menggunakan `.submit()` dan `.ajax()` jQuery untuk Muat Naik Berbilang Fail Asynchronous?

Bagaimana untuk Menggunakan `.submit()` dan `.ajax()` jQuery untuk Muat Naik Berbilang Fail Asynchronous?

DDD
Lepaskan: 2024-11-27 05:36:14
asal
698 orang telah melayarinya

How to Use jQuery's `.submit()` and `.ajax()` for Asynchronous Multiple File Uploads?

Menyerahkan Fail melalui AJAX Menggunakan jQuery '.submit()' dan '.ajax()'

Ikhtisar:

Memuat naik berbilang fail ke pelayan adalah keperluan biasa dalam pembangunan web. Kaedah '.submit()' dan '.ajax()' jQuery menyediakan pendekatan yang mudah untuk menyerahkan borang dan menghantar data ke pelayan secara tidak segerak. Artikel ini membincangkan cara menggunakan kaedah ini untuk memudahkan muat naik berbilang fail.

Borang HTML:

Borang HTML hendaklah mengandungi berbilang medan input fail, dan "Tambah Lagi butang Fail", dan butang hantar. Apabila butang "Tambah Lagi Fail" diklik, medan input fail tambahan ditambahkan secara dinamik.

<form enctype="multipart/form-data" action="upload.php" method="post">
    <input name="file[]" type="file">
    <button class="add_more">Add More Files</button>
    <input type="button">
Salin selepas log masuk

JavaScript untuk Penambahan Input Fail Dinamik:

Kod JavaScript menggunakan jQuery untuk menambah medan input fail tambahan apabila butang "Tambah Lagi Fail" berada diklik.

$(document).ready(function(){
    $('.add_more').click(function(e){
        e.preventDefault();
        $(this).before("<input name='file[]' type='file'>");
    });
});
Salin selepas log masuk

Muat Naik Skrip:

Skrip PHP sebelah pelayan ('upload.php') mengendalikan proses muat naik fail, termasuk pengesahan dan penyimpanan ke direktori sasaran. Ia menganggap struktur direktori hierarki untuk menyusun fail yang dimuat naik.

for($i=0; $i<count($_FILES['file']['name']); $i++){
    $target_path = "uploads/";
    $ext = explode('.', basename( $_FILES['file']['name'][$i]));
    $target_path = $target_path . md5(uniqid()) . "." . $ext[count($ext)-1]; 

    if(move_uploaded_file($_FILES['file']['tmp_name'][$i], $target_path)) {
        echo "The file has been uploaded successfully <br />";
    } else{
        echo "There was an error uploading the file, please try again! <br />";
    }
}
Salin selepas log masuk

jQuery untuk Penyerahan Fail AJAX:

Akhir sekali, '.submit()' dan ' Kaedah .ajax()' digunakan untuk mengikat pendengar acara kepada butang hantar. Apabila diklik, permintaan AJAX dihantar ke skrip 'upload.php' dan data fail yang dimuat naik disertakan dalam permintaan menggunakan objek FormData. Fungsi 'kejayaan' jQuery mengendalikan respons pelayan.

$('body').on('click', '#upload', function(e){
    e.preventDefault();
    var formData = new FormData($(this).parents('form')[0]);

    $.ajax({
        url: 'upload.php',
        type: 'POST',
        xhr: function() {
            var myXhr = $.ajaxSettings.xhr();
            return myXhr;
        },
        success: function (data) {
            alert("Data Uploaded: "+data);
        },
        data: formData,
        cache: false,
        contentType: false,
        processData: false
    });
    return false;
});
Salin selepas log masuk

Dengan melaksanakan pendekatan ini, anda boleh memuat naik berbilang fail secara tidak segerak menggunakan PHP, jQuery dan AJAX dengan berkesan.

Atas ialah kandungan terperinci Bagaimana untuk Menggunakan `.submit()` dan `.ajax()` jQuery untuk Muat Naik Berbilang Fail Asynchronous?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan