Memuat Naik Kedua-dua Data dan Fail dalam Borang Tunggal dengan Ajax
Apabila menggunakan jQuery dan Ajax untuk berinteraksi dengan borang, adalah perkara biasa untuk menyerahkan sama ada data atau fail, tetapi bukan kedua-duanya serentak. Ini boleh menimbulkan cabaran apabila anda perlu memuat naik kedua-dua jenis kandungan.
Penjelasan Masalah
Isu utama terletak pada cara data dan fail yang berbeza dikumpulkan sebelum penyerahan . Data biasanya bersiri menggunakan kaedah .serialize(), manakala fail dikendalikan menggunakan objek FormData.
Penyelesaian
Untuk memuat naik kedua-dua data dan fail dalam satu bentuk melalui Ajax, anda boleh memanfaatkan kuasa FormData. Objek ini membolehkan anda menggabungkan kedua-dua jenis kandungan dengan mudah. Begini caranya:
<form>
$("form#datafiles").submit(function(e) { e.preventDefault(); var formData = new FormData(this); // Gather both data and files into a single FormData object $.ajax({ url: window.location.pathname, // Your PHP endpoint URL type: 'POST', data: formData, success: function(data) { alert(data); // Output the response from your PHP script }, cache: false, contentType: false, processData: false }); });
Skrip PHP
Di bahagian pelayan, skrip PHP anda akan dapat mengakses kedua-dua data dan fail yang diserahkan oleh anda bentuk. Anda boleh menggunakan $_POST dan $_FILES untuk mendapatkan semula maklumat ini.
<?php // Display contents of $_POST print_r($_POST); // Display contents of $_FILES print_r($_FILES); ?>
Kesimpulan
Dengan menggunakan FormData, anda boleh menyerahkan kedua-dua data dan fail dengan mudah daripada satu borang menggunakan Ajax. Pendekatan ini memperkemas borang anda dan meningkatkan kecekapan pengurusan fail dan data anda.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Muat Naik Kedua-dua Data dan Fail Secara serentak Menggunakan Ajax dalam Borang Tunggal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!