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)"
  ...>

ASP.Net MVC Ajax.在Razor视图中传递c#参数

直接创建另一个变量字符串:

@{
    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()将处理所有这些。