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

Api:

cs 复制代码
 /// <summary>
 /// 根据id获取文章
 /// </summary>
 /// <param name="id"></param>
 /// <returns></returns>
 [HttpGet, Route("GetArticleById")]//api/article/GetArticleById
 public 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/12
 public 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中对应的请求方式也有两种:

第一种:

javascript 复制代码
 //定义参数
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:参数编码问题

javascript 复制代码
// 如果文章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:多个参数时很麻烦

javascript 复制代码
// 手动拼接很繁琐且容易出错
request.get(`/Article?id=${id}&category=${category}&page=${page}`);

// 使用params对象更清晰
request.get('/Article', { 
  params: { id, category, page } 
});

第二种:

javascript 复制代码
const response = await request.get(`/Article/${articleId}`);

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

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

相关推荐
小妖66613 分钟前
力扣(LeetCode)- 93. 复原 IP 地址(JavaScript)
javascript·tcp/ip·leetcode
古月฿24 分钟前
大学生素质测评系统设计与实现
java·vue.js·redis·mysql·spring·毕业设计
码农秋27 分钟前
Element Plus DatePicker 日期少一天问题:时区解析陷阱与解决方案
前端·vue.js·elementui·dayjs
未来之窗软件服务31 分钟前
未来之窗昭和仙君(五十六)页面_预览模式——东方仙盟筑基期
前端·仙盟创梦ide·东方仙盟·昭和仙君·东方仙盟架构
top_designer33 分钟前
Illustrato:钢笔工具“退休”了?Text to Vector 零基础矢量生成流
前端·ui·aigc·交互·ux·设计师·平面设计
源码获取_wx:Fegn089534 分钟前
基于springboot + vue物业管理系统
java·开发语言·vue.js·spring boot·后端·spring·课程设计
星哥说事38 分钟前
星哥带你玩飞牛NAS-13:自动追番、订阅下载 + 刮削,动漫党彻底解放双手!
前端
donecoding1 小时前
前端AI开发:为什么选择SSE,它与分块传输编码有何不同?axios能处理SSE吗?
前端·人工智能
安_1 小时前
<style scoped>跟<style>有什么区别
前端·vue
姝然_95271 小时前
Claude Code 命令完整文档
前端