在Web开发中,经常需要将列表形式的数据(如数组、对象集合等)通过Ajax发送到服务器。本文将详细介绍不同场景下如何使用Ajax发送列表数据,包括原生JavaScript、jQuery和现代Fetch API的实现方式,并探讨常见问题及解决方案。

在前端开发中,列表数据通常表现为以下几种形式:
[1, 2, 3, "a", "b"][ { id: 1, name: "Alice" }, { id: 2, name: "Bob" }]{ users: [ { id: 1, roles: ["admin", "editor"] }, { id: 2, roles: ["viewer"] } ]}const userList = [ { id: 1, name: "Alice" }, { id: 2, name: "Bob" }];const xhr = new XMLHttpRequest();xhr.open('POST', '/api/users/batch', true);xhr.setRequestHeader('Content-Type', 'application/json');xhr.onreadystatechange = function() { if (xhr.readyState === 4) { if (xhr.status === 200) { console.log('批量创建成功:', JSON.parse(xhr.responseText)); } else { console.error('请求失败:', xhr.statusText); } }};xhr.send(JSON.stringify(userList));function listToFormData(list) { const params = new URLSearchParams(); list.forEach((item, index) => { params.append(`users[${index}][id]`, item.id); params.append(`users[${index}][name]`, item.name); }); return params.toString();}const userList = [ { id: 1, name: "Alice" }, { id: 2, name: "Bob" }];const xhr = new XMLHttpRequest();xhr.open('POST', '/api/users/batch', true);xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');xhr.onreadystatechange = function() { // 处理响应...};xhr.send(listToFormData(userList));const productList = [ { sku: "A001", price: 99.9 }, { sku: "B002", price: 199.9 }];$.ajax({ url: '/api/products/update', type: 'POST', contentType: 'application/json', data: JSON.stringify(productList), success: function(response) { console.log('批量更新成功:', response); }, error: function(xhr) { console.error('请求失败:', xhr.statusText); }});function createFormData(list) { const formData = new FormData(); list.forEach((item, index) => { formData.append(`items[${index}][sku]`, item.sku); formData.append(`items[${index}][price]`, item.price); }); return formData;}const inventoryList = [ { sku: "A001", price: 99.9 }, { sku: "B002", price: 199.9 }];$.post('/api/inventory/batch', createFormData(inventoryList)) .done(function(response) { console.log('批量入库成功:', response); }) .fail(function(xhr) { console.error('请求失败:', xhr.statusText); });const orderList = [ { orderId: "ORD2023001", status: "shipped" }, { orderId: "ORD2023002", status: "processing" }];fetch('/api/orders/batch-update', { method: 'POST', headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer your_token_here' }, body: JSON.stringify(orderList)}) .then(response => { if (!response.ok) throw new Error('Network response was not ok'); return response.json(); }) .then(data => console.log('批量更新结果:', data)) .catch(error => console.error('请求失败:', error));async function uploadFilesWithMetadata(fileList) { const formData = new FormData(); fileList.forEach((file, index) => { formData.append(`files[${index}]`, file); formData.append(`metadata[${index}][name]`, `file_${index}`); formData.append(`metadata[${index}][size]`, file.size); }); try { const response = await fetch('/api/uploads/batch', { method: 'POST', body: formData // 注意:使用FormData时不要手动设置Content-Type // 浏览器会自动添加正确的boundary }); const result = await response.json(); console.log('上传结果:', result); } catch (error) { console.error('上传失败:', error); }}// 使用示例const fileInput = document.getElementById('fileInput');fileInput.addEventListener('change', (e) => { uploadFilesWithMetadata(Array.from(e.target.files));});问题原因:
Content-Type设置不正确解决方案:
Content-Type: application/jsonapplication/x-www-form-urlencoded或multipart/form-data问题原因:
解决方案:
encodeURIComponent(value)前端示例:
const complexData = { department: "IT", employees: [ { name: "Alice", skills: ["JS", "Python"] }, { name: "Bob", skills: ["Java", "SQL"] } ]};// 发送方式(Fetch API)fetch('/api/department/save', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(complexData)});后端处理(Spring Boot示例):
@PostMapping("/api/department/save")public ResponseEntity<?> saveDepartment(@RequestBody DepartmentDto dto) { // dto应包含department字段和List<EmployeeDto> employees字段 // ...}// Axios上传进度示例axios.post('/api/upload', formData, { onUploadProgress: progressEvent => { const percent = Math.round((progressEvent.loaded * 100) / progressEvent.total); console.log(`上传进度: ${percent}%`); }});// utils/request.jsimport axios from 'axios';export function postList(url, data) { return axios.post(url, data, { headers: { 'Content-Type': 'application/json' } });}// 组件中使用import { postList } from '@/utils/request';export default { methods: { async submitOrders() { const orders = [ { id: 1, qty: 2 }, { id: 2, qty: 1 } ]; try { const response = await postList('/api/orders/batch', orders); // 处理响应... } catch (error) { console.error('提交失败:', error); } } }}// api/batchApi.jsexport const updateProductsBatch = async (products) => { const response = await fetch('/api/products/batch', { method: 'PUT', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify(products) }); return response.json();};// 组件中使用import { updateProductsBatch } from './api/batchApi';function ProductList() { const handleBatchUpdate = async () => { const products = [ { id: 101, price: 19.99 }, { id: 102, price: 29.99 } ]; try { const result = await updateProductsBatch(products); console.log('更新结果:', result); } catch (error) { console.error('更新失败:', error); } }; return ( <button onClick={handleBatchUpdate}>批量更新价格</button> );}发送列表数据是Web开发中的常见需求,选择合适的方法需要考虑:
对于现代项目,推荐优先使用Fetch API或Axios发送JSON格式的列表数据,它们提供了简洁的语法和良好的错误处理机制。在需要兼容旧浏览器或处理复杂表单上传时,XMLHttpRequest仍然是可靠的选择。无论采用哪种方式,始终确保正确设置请求头并验证后端接收的数据结构。
以上就是不同场景下使用Ajax发送列表数据的实践指南的详细内容,更多关于使用Ajax发送列表数据的资料请关注本站其它相关文章!