不同场景下使用Ajax发送列表数据的实践指南

 更新时间:2026年03月25日 08:26:01   作者:detayun  
本文介绍了使用Ajax发送列表数据的不同方法,涵盖原生JavaScript、jQuery和FetchAPI,讨论了常见问题及解决方案,并提供了性能优化建议和不同框架的封装方案,需要的朋友可以参考下

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

一、基础概念:列表数据的常见形式

在前端开发中,列表数据通常表现为以下几种形式:

  1. 简单数组[1, 2, 3, "a", "b"]
  2. 对象数组
[
  { id: 1, name: "Alice" },
  { id: 2, name: "Bob" }
]
  1. 嵌套结构
{
  users: [
    { id: 1, roles: ["admin", "editor"] },
    { id: 2, roles: ["viewer"] }
  ]
}

二、原生JavaScript发送列表数据

1. 使用XMLHttpRequest发送JSON格式列表

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));

2. 发送表单格式的列表数据(application/x-www-form-urlencoded)

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));

三、jQuery发送列表数据

1. 使用$.ajax发送JSON列表

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);
  }
});

2. 使用$.post发送表单格式列表

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);
  });

四、Fetch API发送列表数据

1. 发送JSON列表(推荐方式)

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));

2. 发送FormData列表(适合文件上传场景)

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));
});

五、常见问题及解决方案

1. 后端接收不到数据

问题原因

  • 请求头Content-Type设置不正确
  • 数据序列化格式与后端期望不符

解决方案

  • 确保JSON数据发送时设置:Content-Type: application/json
  • 表单数据发送时使用application/x-www-form-urlencodedmultipart/form-data
  • 使用开发者工具检查实际发送的请求体

2. 列表数据被截断

问题原因

  • URL参数方式传输时长度限制
  • 未正确处理特殊字符

解决方案

  • 大数据量优先使用POST而非GET
  • 对参数进行URL编码:encodeURIComponent(value)
  • 考虑使用JSON格式而非键值对

3. 嵌套列表结构处理

前端示例

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字段
    // ...
}

六、性能优化建议

  1. 批量操作:尽量将多个单条操作合并为批量请求
  2. 压缩传输:对大JSON数据启用Gzip压缩
  3. 分片上传:超大文件采用分片上传策略
  4. 进度监控:使用XMLHttpRequest或Axios的进度事件
// Axios上传进度示例
axios.post('/api/upload', formData, {
  onUploadProgress: progressEvent => {
    const percent = Math.round((progressEvent.loaded * 100) / progressEvent.total);
    console.log(`上传进度: ${percent}%`);
  }
});

七、不同框架的封装方案

1. Vue.js中的封装

// utils/request.js
import 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);
      }
    }
  }
}

2. React中的封装

// api/batchApi.js
export 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开发中的常见需求,选择合适的方法需要考虑:

  1. 数据量大小
  2. 是否需要传输文件
  3. 后端API设计
  4. 项目技术栈

对于现代项目,推荐优先使用Fetch API或Axios发送JSON格式的列表数据,它们提供了简洁的语法和良好的错误处理机制。在需要兼容旧浏览器或处理复杂表单上传时,XMLHttpRequest仍然是可靠的选择。无论采用哪种方式,始终确保正确设置请求头并验证后端接收的数据结构。

以上就是不同场景下使用Ajax发送列表数据的实践指南的详细内容,更多关于使用Ajax发送列表数据的资料请关注脚本之家其它相关文章!

相关文章

  • Ajax缓存问题的解决方法汇总

    Ajax缓存问题的解决方法汇总

    Ajax的缓存问题,是比较烦人的,不过是有解决方法的,而且还不止一种,可以在URL后面加上一个随机数或时间搓都可以的
    2014-08-08
  • jquery访问servlet并返回数据到页面的方法

    jquery访问servlet并返回数据到页面的方法

    这篇文章主要介绍了jquery访问servlet并返回数据到页面的方法,实例分析了jQuery操作servlet实现Ajax的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • Ajax传递特殊字符的数据如何解决

    Ajax传递特殊字符的数据如何解决

    这篇文章给大家介绍了Ajax传递的数据包含特殊字符时的解决方法,需要的朋友参考下吧
    2017-06-06
  • AJAX实现无刷新检测用户名功能

    AJAX实现无刷新检测用户名功能

    这篇文章主要为大家详细介绍了AJAX实现无刷新用户名检测功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Ajax和跨域问题深入解析

    Ajax和跨域问题深入解析

    这篇文章主要为大家详细介绍了Ajax和跨域问题,告诉大家什么Ajax,什么是跨域?具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • 探讨Ajax中同步与异步之间的区别

    探讨Ajax中同步与异步之间的区别

    这篇文章主要是对Ajax中同步与异步之间的区别进行了详细的分析介绍。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • 基于HTML5的可预览多图片Ajax上传

    基于HTML5的可预览多图片Ajax上传

    这篇文章主要为大家详细介绍了基于HTML5的可预览多图片Ajax上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • AJAX跨域请求JSONP获取JSON数据的实例代码

    AJAX跨域请求JSONP获取JSON数据的实例代码

    Asynchronous JavaScript and XML (Ajax) 是驱动新一代 Web 站点(流行术语为 Web 2.0 站点)的关键技术。Ajax 这篇文章主要介绍了AJAX跨域请求JSONP获取JSON数据的实例代码,需要的朋友可以参考下
    2017-02-02
  • 关于ajax网络请求的封装实例

    关于ajax网络请求的封装实例

    下面小编就为大家带来一篇关于ajax网络请求的封装实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-07-07
  • Ajax实现异步加载数据

    Ajax实现异步加载数据

    这篇文章主要为大家详细介绍了Ajax实现异步加载数据,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11

最新评论