ASP.Net MVC Ajax.在Razor视图中传递c#参数
本文关键字:参数 视图 Razor Net MVC Ajax ASP | 更新日期: 2023-09-27 18:08:42
我在MVC c# Razor视图中有以下代码:
@{string url = "/Projects/_MonthRangesScriptsPartial";}
@using (Ajax.BeginForm(
"_MonthRanges",
"Projects",
new { id = ViewBag.InputResourceID },
new AjaxOptions {
HttpMethod = "POST",
UpdateTargetId = "MonthRanges",
InsertionMode = InsertionMode.Replace,
OnComplete = "updategraphArrayScript(@url,@ViewBag.InputResourceID)"
}))
代码几乎完美地工作,但我想解决c#变量的值在OnComplete行。
也就是说,Razor引擎应该将代码解析为(例如):<form action="/Projects/_MonthRanges/55"
data-ajax="true" data-ajax-complete="updategraphArrayScript(/Projects/assets,55)"
...>
而不是:
<form action="/Projects/_MonthRanges/55"
data-ajax="true" data-ajax-complete="updategraphArrayScript(@url,@ViewBag.InputResourceID)"
...>
直接创建另一个变量字符串:
@{
string url = "/Projects/_MonthRangesScriptsPartial";
string onComplete = String.Format("updategraphArrayScript({0}, {1})", url, ViewBag.InputResourceID);
}
@using (Ajax.BeginForm(
"_MonthRanges",
"Projects",
new { id = ViewBag.InputResourceID },
new AjaxOptions {
HttpMethod = "POST",
UpdateTargetId = "MonthRanges",
InsertionMode = InsertionMode.Replace,
OnComplete = @onComplete
}))
在分配OnComplete值时去掉@。你不需要它,因为你已经在服务器端代码的上下文中了。
@
用于将html呈现上下文切换到服务器端代码,<text></text>
用于从服务器端上下文切换到html呈现。在上面给出的示例中,您已经处于BeginForm()
方法的服务器端代码上下文中,因此不需要@。您没有将onComplete
的值写入页面,BeginForm()
将处理所有这些。