Fetch 基础用法优化

1. GET 请求(带参数)
  • URL拼接优化:使用 URLSearchParams 自动编码特殊字符,避免手动处理:
    const params = new URLSearchParams({
          page: 1, limit: 10, keyword: '测试' });
    fetch(`/api/data?${
           params}`)
      .then(response => response.json())
      .then(data => console.log(data));
    
  • 手动编码场景:若需手动拼接 URL,使用 encodeURIComponent
    const keyword = encodeURIComponent('测试&特殊字符');
    fetch(`/api/search?keyword=${
           keyword}`);
    
2. POST 请求(JSON 格式)
  • Content-Type 必须设置:未设置会导致服务器无法解析 JSON:
    fetch('/api/submit', {
         
      method: 'POST',
      headers: {
         
        'Content-Type': 'application/json' // 必须明确指定
      },
      body: JSON.stringify({
          name: 'Alice', age: 25 })
    });
    

二、处理不同请求数据格式的注意事项

1. x-www-form-urlencoded 格式
  • 编码规则URLSearchParams 自动处理空格(转为 +)和特殊字符编码:
    const formData =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端熊猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值