通过使用jQuery脚本调用URL.Action生成的URI中的转义字符

时间:2012-01-07 07:54:04

标签: asp.net-mvc-3 razor escaping jquery-ui-dialog

我有以下代码作为jquery脚本的一部分来打开jqueryui对话框(id值是硬编码的,用于测试目的):

        open: function (event, ui) {

            $(this).load("@Url.Action("Edit", "Person",
                new
                {
                    id = Guid.Parse("28769371-7518-49db-a5ea-b9c62621a609"),
                    selectedPersonFor = Model.SelectedPersonFor,
                    selectedPersonForId = Model.SelectedPersonForId,
                    clientAccountId = Model.ClientAccountId
                })");
        },

我遇到的问题是,即使我的对话框打开,控制器操作也永远不会被命中。

如果我在浏览器中查看源代码,则产生的输出为:

open: function (event, ui) {

            $(this).load("/Person/Edit/28769371-7518-49db-a5ea-b9c62621a609?selectedPersonFor=ClientAccount&selectedPersonForId=2a2dd3b9-a73b-4afa-8237-5a4f37736f8a&clientAccountId=00000000-0000-0000-0000-000000000000");
        },

我发现如果我将上面的URI硬编码到我的脚本中并用非转义的&符号(&)替换转义的&符号(&),那么我的控制器操作就会被击中。

我尝试在我的脚本中添加对replace方法的调用来摆脱转义的&符号,但这没有用。当我查看为调用控制器操作而生成的同一页面中的其他URI时,但不在脚本中,我注意到它们已经在其中转义了&符号。

浏览器如何处理来自脚本的控制器操作的调用,以及它是如何从脚本外部执行的 - 以及所有与转义的&符号相关的内容似乎有所不同。

有人可以指导我如何克服这个问题吗?

更多信息:

我还尝试将查询参数传递给加载函数,如下所示:

open: function (event, ui) {

            $(this).load("@Url.Action("Edit", "Person")",
                {
                    id: @Guid.Parse("28769371-7518-49db-a5ea-b9c62621a609"),
                    selectedPersonFor: Model.SelectedPersonFor,
                    selectedPersonForId: Model.SelectedPersonForId,
                    clientAccountId: Model.ClientAccountId
                });
        },

然而,当我这样做时,我的对话框甚至都没有打开。

编辑:

响应显示路线的请求,我提供以下内容(希望这是所要求的内容):

routes.MapRoute(
            "Default", // Route name
            "{controller}/{action}/{id}", // URL with parameters
            new { controller = "Home", action = "Index", id = UrlParameter.Optional } // Parameter defaults
        );

我只是使用我的asp.net mvc3项目提供的默认路由。

1 个答案:

答案 0 :(得分:6)

在Razor中,@运算符用于HTML编码输出=> &变为&。如果您不希望发生这种情况,可以使用Html.Raw帮助程序:

var url = '@Html.Raw(Url.Action("Edit", "Person", new {
    id = Guid.Parse("28769371-7518-49db-a5ea-b9c62621a609"),
    selectedPersonFor = Model.SelectedPersonFor,
    selectedPersonForId = Model.SelectedPersonForId,
    clientAccountId = Model.ClientAccountId
}))';
$(this).load(url);

现在让我们考虑你的第二个代码片段:

$(this).load("@Url.Action("Edit", "Person")", {
    id: @Guid.Parse("28769371-7518-49db-a5ea-b9c62621a609"),
    selectedPersonFor: Model.SelectedPersonFor,
    selectedPersonForId: Model.SelectedPersonForId,
    clientAccountId: Model.ClientAccountId
});

如果你看一下呈现的HTML,你会看到:

$(this).load("@Url.Action("Edit", "Person")", {
    id: 28769371-7518-49db-a5ea-b9c62621a609,
    selectedPersonFor: Model.SelectedPersonFor,
    selectedPersonForId: Model.SelectedPersonForId,
    clientAccountId: Model.ClientAccountId
});

这显然不起作用,因为Model.SelectedPersonForId可能不是一个有效的javascript变量,所以你得到一个javascript错误。此外,28769371-7518-49db-a5ea-b9c62621a609不是有效的javascript表达式,因为您没有用引号括起来。

如果您希望这一点起作用,请确保生成适当的内容:

$(this).load("/Person/Edit", {
    id: '@Guid.Parse("28769371-7518-49db-a5ea-b9c62621a609")',
    selectedPersonFor: '@Model.SelectedPersonFor',
    selectedPersonForId: '@Model.SelectedPersonForId',
    clientAccountId: '@Model.ClientAccountId'
});

注意在每个服务器端变量之前使用的@运算符,而不仅仅是在Guid之前。另请注意,值包装为javascript字符串。