ASP.NET Core - 在没有Ajax的情况下调用javascript中的控制器方法

问题描述 投票:3回答:2

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

我见过很多人使用Ajax,但问题是我想调用控制器,而控制器又将用户重定向到View“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所期望的那样,它确实返回了View,但它将它作为对ajax查询的响应返回,因此它不会重定向并显示我想要的View。

javascript controller asp.net-core-mvc
2个回答
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期望您的参数来自路线。


0
投票

你可以这么做

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

如果您的默认路由没有问题,则无需更改Action方法路由。

© www.soinside.com 2019 - 2024. All rights reserved.