从 javascript 中的 Url.Action 个变量传递 url 参数

Passing url parameters from Url.Action variables in javascript

我想通过提及我已阅读问题来开始我的问题

Passing dynamic javascript values using Url.action()

How to pass parameters from @Url.Action to controller

为了拥有更简洁的代码和使用 javascript 函数打开模态 windows 并以 url 作为论据,我不喜欢在我的 javascript 文件中使用 Razor。出于这个原因,我在 .cshtml 页面的 PageScripts 中设置了我所有的 Url 操作,并在我的函数中使用了变量。

@section PageScripts {
    // render necessairy scripts
    <script type="text/javascript">
        view.params = {
            exampleUrl: "@Url.Action("ExampleAction", "ExampleController", new { parameter1Id = "pr1Id", parameter2Id = "pr2Id", parameter3Id = "pr3Id" })",
            // More url actions and page module parameters
        }
    };
    </script>
}

此类 url 操作用于模态 windows 我必须从必须使用许多参数的选定行中打开。我在 javascript 函数中使用它们的方式是这样的

var uri = params.exampleUrl.replace('pr1Id', actualParameter1Id).replace('pr2Id', actualParameter2Id).replace('pr3Id', actualParameter3Id);

我的控制器是这样的

public ActionResult ExampleAction(string parameter1Id, string parameter2Id, string parameter3Id){
    // do stuff and return View...
}

我的问题是,当我传递一个参数时,我的控制器正确获取了值。当我传递多个参数时,虽然我从调试中看到 uri 参数已更改并采用了新参数,但在我的控制器中只有第一个参数正确。其他变量即将变为空。

示例:

addCandidateTaskUrl: "@Url.Action("Action", "Controller", new { candidacyId = "cId", candidateId = "cndId",  typeOfAction = "tpA" })"

来自参数的 Uri

"/ApplicationName/Controller/Action?candidacyId=cId&amp;candidateId=cnId&amp;typeOfAction=tpA"

替换值后的 Uri

"/ApplicationName/Controller/Action?candidacyId=97c89ac6-3571-48a1-a904-d4b3f2594d9b&amp;candidateId=a05amn84-33a1-4fcb-8c89-e44635d67d63&amp;typeOfAction=COMPLETED"

您在脚本中使用 Url.Action() 会在 url 中生成 &amp; 而不是 &,因此不是

../Controller/Action?candidacyId=cId&amp;candidateId=cnId&amp;typeOfAction=tpA"

你需要生成

../Controller/Action?candidacyId=cId&candidateId=cnId&typeOfAction=tpA"

您可以将其包装在 Html.Raw() 中,这样它就不会被编码

addCandidateTaskUrl: "@Html.Raw(Url.Action("Action", "Controller", new { candidacyId = "cId", candidateId = "cndId",  typeOfAction = "tpA" }))"

但是,您可以通过仅生成基础 url 并使用 $.param method

view.params = {
    baseUrl: '@Url.Action("Action", "Controller")' // Html.Raw not required

var queryString = $.param({ param1Id: actualParam1Id, param2Id: actualParam2Id, ... });
var uri = params.baseUrl + '?' + queryString;