news 2026/6/23 23:02:14

原生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/6/23 16:57:03

QQ截图独立版:解锁Windows屏幕捕捉新体验的完整手册

QQ截图独立版:解锁Windows屏幕捕捉新体验的完整手册 【免费下载链接】QQScreenShot 电脑QQ截图工具提取版,支持文字提取、图片识别、截长图、qq录屏。默认截图文件名为ScreenShot日期 项目地址: https://gitcode.com/gh_mirrors/qq/QQScreenShot 还在为复杂的…

作者头像 李华
网站建设 2026/6/23 13:50:59

Emby界面美化完全手册:3种方法打造专属影音中心

还在为Emby单调的界面而烦恼吗?想要打造一个既美观又实用的个人影音中心,却不知从何入手?这份完全手册将为你揭秘三种简单易行的Emby界面美化方案,让新手也能轻松上手,快速实现界面升级。 【免费下载链接】emby-crx Em…

作者头像 李华
网站建设 2026/6/23 16:56:07

EmotiVoice语音能量调节功能改善发音力度

EmotiVoice语音能量调节功能改善发音力度 在虚拟主播激情澎湃地喊出“这波福利冲啊!”时,你是否曾被那股扑面而来的情绪张力所感染?又或者,在有声书中听到角色低声啜泣时心头一紧——这些细腻的情感表达背后,早已不是简…

作者头像 李华
网站建设 2026/6/23 1:41:17

Blender版本管理革命:智能化工具如何重塑3D创作工作流

Blender版本管理革命:智能化工具如何重塑3D创作工作流 【免费下载链接】Blender-Launcher Standalone client for managing official builds of Blender 3D 项目地址: https://gitcode.com/gh_mirrors/bl/Blender-Launcher 在3D创作领域,Blender的…

作者头像 李华
网站建设 2026/6/23 17:02:32

5、Linux 命令使用指南

Linux 命令使用指南 1. Linux 基础概念 在 Linux 系统中,有一些基础概念容易让人混淆。比如存在三个“根”相关的概念: - “/” 目录被称为根目录,它是文件系统的起始点。 - 系统管理员被称为根用户(root user)。 - 根用户的主目录是 “/root” 目录。为避免混淆,Li…

作者头像 李华