当前位置: 首页 > news >正文

Vue 与.Net Core WebApi交互时路由初探

Api:

 /// <summary>/// 根据id获取文章/// </summary>/// <param name="id"></param>/// <returns></returns>[HttpGet, Route("GetArticleById")]//api/article/GetArticleByIdpublic async Task<IActionResult> GetArticleById( int id){ApiResult<Article> apiResult = await _articleService.GetArticleById(id);return Ok(apiResult);}/// <summary>/// 通过文章编号,获取文章详情信息/// </summary>/// <param name="id">文章编号</param>/// <returns></returns>[HttpGet, Route("{id}")] //api/article/12public async Task<IActionResult> GetArticle(long id){Article article = await _articleService.FindAsync(id);ApiResult<Article> apiResult = new();apiResult.Data = article;apiResult.Code = article == null ? 404 : 200;apiResult.Message = article == null ? "文章详情信息不存在!" : "获取文章详情信息";return Ok(apiResult);}

我的接口中定义了两个方法,实现了同样的功能,但是对外提供的访问路由不同。

第一个是://api/article/GetArticleById  然后接收一个int类型的参数,

第二个是://api/article/12 12就是需要调用者直接提供的参数,12只是演示,当然也可以其他数字。

请求:

针对上方Api在Vue中对应的请求方式也有两种:

第一种:

 //定义参数
const correctedParams = {id: articleId ,};
const response = await request.get('/Article/GetArticleById', { params: correctedParams });

这种方法实际请求的url是:

/Article/GetArticleById?id=123  

(123也是演示用的)

然后就可以手动拼接:

request.get(`/Article/GetArticleById?id=${articleId }`);

注意这里是反引号 ` 而不是单引号 ' 。

但是手动拼接的话有一些隐患:

问题1:参数编码问题

// 如果文章ID包含特殊字符
const id = "123&type=test";
request.get(`/Article?id=${id}`); 
// → /Article?id=123&type=test (错误解析为两个参数)// 正确的方式会自动编码:
request.get('/Article', { params: { id: "123&type=test" } });
// → /Article?id=123%26type%3Dtest (正确编码)

问题2:多个参数时很麻烦

// 手动拼接很繁琐且容易出错
request.get(`/Article?id=${id}&category=${category}&page=${page}`);// 使用params对象更清晰
request.get('/Article', { params: { id, category, page } 
});

第二种:

const response = await request.get(`/Article/${articleId}`);

这种方法就直接把id当作路由的一部分来调用。

根据项目封装的axios接口不同,方法上可能有差异,这里只是引入一下我的经历作为参考。

http://www.dtcms.com/a/460731.html

相关文章:

  • 怎么建立自己公司的网站软文营销案例分析
  • 深圳专业网站建设公司辽宁工程建设招标网
  • 抖音a_bogus参数加密逆向
  • 【网络编程】网络通信基石:从局域网到跨网段通信原理探秘
  • 百度免费做网站江苏鑫圣建设工程有限公司网站
  • 4. React中的事件绑定:基础事件;使用事件对象参数;传递自定义参数;同时传递事件参数和自定义参数
  • 解析Oracle 19C中并行INSERT SELECT的工作原理
  • SLAM-Former: Putting SLAM into One Transformer论文阅读
  • Vue3 + TypeScript provide/inject 小白学习笔记
  • 【开题答辩过程】以《基于springboot交通旅游订票系统设计与实现》为例,不会开题答辩的可以进来看看
  • 免费企业网站模板html北京网站制作设计价格
  • 网络编程(十二)epoll的两种模式
  • 某大厂跳动面试:计算机网络相关问题解析与总结
  • 服务器数据恢复—Raid5双硬盘坏,热备盘“罢工”咋恢复?
  • Vue2.0中websocket的使用-demo
  • 海外IP的适用业务范围
  • eBPF 加速时代,【深入理解计算机网络05】数据链路层:组帧,差错控制,流量控制与可靠传输的 10 Gbps 实践
  • simple websocket用法
  • 主流网络协议--助记
  • Python网络编程——UDP编程
  • 个人网站的设计流程seo资源网
  • 绿泡守护者:禁止微信更新
  • 服务端架构演进概述与核心技术概念解析
  • 美颜滤镜SDK:社交产品破局与增长的核心引擎
  • 三维模型数据结构与存储方式解析
  • 可以使用多少列创建索引?
  • 技术分享|重组单克隆抗体制备全流程:从抗体发现到纳米抗体应用,关键步骤与优势解析
  • 缝合怪deque如何综合list和vector实现及仿函数模板如何优化priority_queue实现
  • H5响应式网站示例企业网app下载
  • cmd什么命令可以知道本机到目标机的ip节点