news 2026/4/23 8:53:35

原生JS请求API

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
原生JS请求API

GET方式前端- 多个参数

// 场景:查询数据 GET方式asyncfunctiongetData(){constparams={sceneId:'order_123',userId:'user_456',type:'normal'};// 方式2:使用URLSearchParams(推荐)constqueryString=newURLSearchParams(params).toString();consturl2=`/api/data?${queryString}`;constresponse=awaitfetch(url2);constdata=awaitresponse.json();returndata;}

GET方式后端:

[HttpGet("data")] public IActionResult GetData([FromQuery] SceneQueryParams query) { // 直接通过对象访问 return Ok(new { query.SceneId, query.UserId, query.Type, message = "GET请求成功" }); }

POST方式-前端:

// 场景:提交复杂对象asyncfunctioncreateOrder(){constpostData={sceneId:'order_123',userInfo:{name:'张三',phone:'13800000000'},items:[{id:1,price:99.9},{id:2,price:199.9}]};constresponse=awaitfetch('/api/order',{method:'POST',// 指定POST方法headers:{'Content-Type':'application/json'// 声明发送JSON},body:JSON.stringify(postData)// 序列化为JSON字符串});if(!response.ok){thrownewError(`请求失败:${response.status}`);}constresult=awaitresponse.json();console.log('创建成功:',result);returnresult;}

POST方式-后端:

[HttpPost("order")] public IActionResult CreateOrder([FromBody] OrderDto dto) { // dto已经自动反序列化 return Ok(new { success = true, message = "订单创建成功", sceneCode = $"{dto.SceneId}_{Random.Shared.Next(0, 1000000).ToString("D6)}" }); }

再举例-修改数据:POST

后端控制器
// Controllers/SceneController.cs [ApiController] [Route("api/scene")] public class SceneController : ControllerBase { [HttpPost("update-code")] public IActionResult UpdateSceneCode([FromBody] string sceneId) { // 参数验证 if (string.IsNullOrWhiteSpace(sceneId)) return BadRequest(new { success = false, message = "sceneId不能为空" }); try { // 生成场景编码 string sceneCode = $"{sceneId}_{Random.Shared.Next(0, 1000000).ToString("D6)}"; // **模拟数据库更新**(实际项目中替换为真实DB操作) Console.WriteLine($"[模拟数据库更新] sceneId={sceneId}, sceneCode={sceneCode}"); return Ok(new { success = true, sceneCode, message = "生成成功" }); } catch (Exception ex) { // 记录错误日志(实际项目中用ILogger) Console.WriteLine($"[错误] {ex.Message}"); return StatusCode(500, new { success = false, message = "服务异常" }); } } }
前端JS
// 按钮事件:传递sceneIdasyncfunctiongenerateAndSaveSceneCode(sceneId){// 验证参数if(!sceneId){alert('sceneId不能为空');return;}// 显示加载状态constbutton=document.activeElement;if(button)button.disabled=true;try{// POST提交单个参数constresponse=awaitfetch('/api/scene/update-code',{method:'POST',headers:{'Content-Type':'application/json'},body:JSON.stringify(sceneId)// 直接序列化字符串});if(!response.ok){thrownewError(`HTTP错误:${response.status}`);}constresult=awaitresponse.json();if(result.success){// 成功后打开二维码页面consturl=`/miniprogram/checkinqrcode.html?scene=${encodeURIComponent(result.sceneCode)}`;window.open(url,'_blank','noopener,noreferrer');console.log('场景编码生成成功:',result.sceneCode);}else{alert('生成失败: '+result.message);}}catch(error){console.error('操作失败:',error);alert('生成失败: '+error.message);}finally{// 恢复按钮状态if(button)button.disabled=false;}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 16:17:41

22、网络文件传输与备份实用工具指南

网络文件传输与备份实用工具指南 在网络环境中,我们经常需要在不同主机之间安全地复制文件、进行文件备份以及非交互式地下载文件。本文将介绍几个实用的工具,包括 scp 、 rsync 和 wget ,并详细讲解它们的使用方法和相关选项。 1. 常用服务器命令 在开始介绍文件传…

作者头像 李华
网站建设 2026/4/22 14:58:14

5个实战理由:为什么PyTorch是AI绘画工具的明智选择

5个实战理由:为什么PyTorch是AI绘画工具的明智选择 【免费下载链接】stable-diffusion-webui-forge 项目地址: https://gitcode.com/GitHub_Trending/st/stable-diffusion-webui-forge 想要构建稳定可靠的AI绘画应用?Stable Diffusion WebUI For…

作者头像 李华
网站建设 2026/4/23 14:44:22

Java代码结构可视化:轻松掌握复杂系统调用关系的终极指南

Java代码结构可视化:轻松掌握复杂系统调用关系的终极指南 【免费下载链接】java-all-call-graph java-all-call-graph - 一个工具,用于生成 Java 代码中方法之间的调用链,适合进行代码分析、审计或确定代码修改影响范围的开发者。 项目地址…

作者头像 李华
网站建设 2026/4/23 11:15:13

Windows任务栏革命:用Taskbar Groups打造极致高效工作环境

混乱中的曙光 【免费下载链接】taskbar-groups Lightweight utility for organizing the taskbar through groups 项目地址: https://gitcode.com/gh_mirrors/ta/taskbar-groups 每天打开电脑,你是否也曾面对任务栏上密密麻麻的图标感到无从下手?…

作者头像 李华
网站建设 2026/4/23 11:14:05

Postman便携版:Windows系统下的高效API开发神器

Postman便携版:Windows系统下的高效API开发神器 【免费下载链接】postman-portable 🚀 Postman portable for Windows 项目地址: https://gitcode.com/gh_mirrors/po/postman-portable 想要在Windows系统中快速搭建API测试环境?Postma…

作者头像 李华
网站建设 2026/4/23 7:05:03

28、ClamAV 杀毒软件配置、测试与自动化更新全解析

ClamAV 杀毒软件配置、测试与自动化更新全解析 1. ClamAV 配置优化 为了减少网络流量开销并确保从地理位置较近的服务器获取更新,我们需要对 ClamAV 进行一些重要配置。 - 数据库镜像配置 : # database.clamav.net 是一个轮询记录,指向最可靠的镜像。 # 当 db.XY.cla…

作者头像 李华