news 2026/4/18 5:23:20

原生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/3 1:17:16

FindSomething浏览器插件:终极隐私安全防护完整指南

在数字化时代,个人信息安全已成为每个网民必须面对的重要课题。FindSomething浏览器插件作为一款专业的被动式信息泄漏检测工具,为您的网络浏览体验提供了全方位的隐私保护解决方案。 【免费下载链接】FindSomething 基于chrome、firefox插件的被动式信息…

作者头像 李华
网站建设 2026/4/9 22:30:29

告别复杂操作!这款多媒体转码工具让视频处理变得如此简单

告别复杂操作!这款多媒体转码工具让视频处理变得如此简单 【免费下载链接】FFBox 一个多媒体转码百宝箱 / 一个 FFmpeg 的套壳 项目地址: https://gitcode.com/gh_mirrors/ff/FFBox 还在为视频格式转换而头疼吗?面对各种专业术语和复杂参数&#…

作者头像 李华
网站建设 2026/4/14 2:08:07

BiliPlus:重新定义你的B站观看体验

BiliPlus:重新定义你的B站观看体验 【免费下载链接】biliplus 🧩 A Chrome/Edge extension to feel better in bilibili.com 项目地址: https://gitcode.com/gh_mirrors/bi/biliplus 还在为B站首页的杂乱推荐而烦恼吗?是否觉得视频播放…

作者头像 李华
网站建设 2026/4/17 3:56:49

VMware Unlocker技术解析:实现非苹果硬件macOS虚拟化的核心方案

VMware Unlocker技术解析:实现非苹果硬件macOS虚拟化的核心方案 【免费下载链接】unlocker 项目地址: https://gitcode.com/gh_mirrors/unlo/unlocker VMware Unlocker是一个专门解决macOS在VMware虚拟化环境中运行限制的开源工具。通过智能二进制补丁技术&…

作者头像 李华
网站建设 2026/3/30 21:16:14

【技术教程】3步极速接入GPT-5.1:零门槛体验多模态AI能力

一、3步极速接入GPT-5.1,零门槛上手步骤1:获取GPT-5.1专属API Key完成平台注册登录后,系统将自动发放GPT-5.1免费体验额度,无需提交额外申请材料,即时到账可用;登录后台管理系统,进入「API令牌管…

作者头像 李华
网站建设 2026/4/13 13:33:35

EmotiVoice是否支持语音情感强度曲线编辑?

EmotiVoice是否支持语音情感强度曲线编辑? 在虚拟偶像的直播中,一句台词从轻声细语逐渐升华为情绪爆发;在有声读物里,叙述者的声音随着情节推进悄然染上紧张或哀伤——这些细腻的情感变化,早已超越了“开心”或“生气”…

作者头像 李华