我有以下代码作为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项目提供的默认路由。
答案 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字符串。