【问题标题】:ASP.NET Core - Call controller method in javascript without AjaxASP.NET Core - 在没有 Ajax 的 javascript 中调用控制器方法
【发布时间】:2018-03-05 11:37:42
【问题描述】:

我想调用我的控制器“Project”的方法“EditProject”,参数是项目的 ID。

我见过很多人使用 Ajax,但问题是我想调用控制器,而控制器又会将用户重定向到视图“EditProject”,我不想停留在同一页面上

这是我在发现它不起作用之前尝试过的代码:

$('.edit-project').click(function (d) {
    var id = $(this).attr('data-projectId');

    $.ajax({
        url: '@Url.Action("EditProject", "Project")',
        data: { id: id },
        type: "GET"
    }).done(function() {
        console.log("Done");
    });
    return false;
});

我也尝试过简单地使用

$.get("/Project/EditProject/" +id); 
window.location.href = '@Url.Action("EditProject", "Project")' + '/' + id;
window.location.href = ("/Project/EditProject/" +id);

但它会返回 404 错误。

调用的方法很简单:

[HttpGet]
[Authorize(Roles = "Professional")]
public async Task<IActionResult> EditProject(int id)
{
    Project p = await _unitOfWork.Projects.GetById(id);
     ViewData["Title"] = "Modification du challenge " + p.ProjectName;
     return View(p);
}

正如 Ajax 所期望的那样,它确实返回了视图,但它作为对 ajax 查询的响应返回它,因此它不会按照我的意愿重定向和显示视图。

【问题讨论】:

  • 这是错字吗$.get("/Project/EditProject/ +id"); 你的意思是$.get("/Project/EditProject/" +id);
  • 在我看来它只需要window.location.href = "/Project/EditProject/" + id;
  • 是的,这是一个错字,我也尝试过 window.location.href,但它实际上从未从控制器调用该方法。我试过放一个断点,它永远不会停止。

标签: javascript controller asp.net-core-mvc


【解决方案1】:

您只是想重定向到那里。

window.location.href = '@Url.Action("EditProject", "Project")' + '/' + id

可能有一种 MVC 方法可以将您的 id 传递给 @Url.Action,但我不太熟悉 - 字符串连接应该可以工作。

控制器可能不理解/1 的含义。您可能需要将其更改为以下内容:

[HttpGet("{id}", Name = "EditProject")]
[Authorize(Roles = "Professional")]
public async Task<IActionResult> EditProject([FromRoute] int id)
{
    Project p = await _unitOfWork.Projects.GetById(id);
     ViewData["Title"] = "Modification du challenge " + p.ProjectName;
     return View(p);
}

这告诉 MVC 期望你的参数来自路由。

【讨论】:

  • 似乎没有从Controller调用方法,我的调试并没有停在里面的断点处,我完全确定方法名没有错别字
  • 当您触发点击处理程序时,浏览器是否真的在某处导航?
  • 它确实,它转到localhost:44311/Project/EditProject/1,这在技术上是我想要的,除了它由于某种原因没有调用控制器?
【解决方案2】:

你可以这样做

window.location.href = '@Url.Action("EditProject", "Project",new { id = ID })';

如果您的默认路由没问题,您不必更改 Action 方法路由。

【讨论】:

    猜你喜欢
    • 2021-09-19
    • 1970-01-01
    • 2014-06-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-29
    • 1970-01-01
    相关资源
    最近更新 更多