写代码时,修改传入参数值的这种行为可取吗?

修改前代码

public IActionResult GetOrders(OrderSearch model)
{
    if (ModelState.IsValid)
    {               
        model.UserId = HttpContextRepository.GetUserId(HttpContext);
        return Json(ServiceIns.GetOrders(model));
    }
    return Json(new Response<string> { ErrMsg = "查询参数不规范" });
}

修改后代码(通过viewmodel方式解决)

class OrderViewModel
{
    public string UserId {get;set;}
}

public IActionResult GetOrders(OrderSearch model)
{
    if (ModelState.IsValid)
    {
        var orderViewModel= new OrderViewModel{ UserId = HttpContextRepository.GetUserId(HttpContext) };
        return Json(ServiceIns.GetOrders(model,orderViewModel));
    }
    return Json(new Response<string> { ErrMsg = "查询参数不规范" });
}
阅读 3k
1 个回答

单看这么几行代码无法回答这个问题。
有几个原则楼主可以参考下:
1、增加代码重用性
2、降低代码耦合度,将易变化的部分跟不易变化的部分分离
3、增加可测试性(容易单元测试)
4、增加易读性

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进