1

MVC で Ajax ActionResult にデータを追加する方法はありますか?

コントローラーで新しい PartialView を作成し、そこにデータを追加して、Ajax OnSuccess 関数で取得できるようにしたいと考えています。

カスタム データを含むコントローラから Json の結果を返し、それを OnSuccess 関数で使用しようとしましたが、カスタム データのみを返し、HTML を返さなかったため、Ajax UpdateTarget div が空白になりました。 HTMLではない私のJson結果でdivを埋めます。

私の UpdateTarget div が更新されるように、コントローラが PartialView を送り返す方法が必要です。これには、OnSuccess 関数で使用できる独自のカスタム データも含まれています。

どんな助けでも大歓迎です。

ありがとうマイク

4

1 に答える 1

1

コントローラーで次のメソッドを使用できます。

  public string UpdateDivWithContent()
  {
      var yourModel = ... //make custom data to create your partial    
      return RenderPartialViewToString("YourPartialViewName", yourModel)
  }

このメソッドを基本コントローラーに入れました:

  protected string RenderPartialViewToString(string viewName, object model)
    {
        if (string.IsNullOrEmpty(viewName))
        {
            viewName = ControllerContext.RouteData.GetRequiredString("action");
        }

        ViewData.Model = model;

        using (StringWriter sw = new StringWriter())
        {
            ViewEngineResult viewResult = ViewEngines.Engines.FindPartialView(ControllerContext, viewName);
            ViewContext viewContext = new ViewContext(ControllerContext, viewResult.View, ViewData, TempData, sw);
            viewResult.View.Render(viewContext, sw);

            return sw.GetStringBuilder().ToString();
        }
    }

手動の ajax 呼び出しを使用して、ビューからこのアクションを呼び出します。次に例を示します。

$.ajax({
    url: '@(Url.Action("UpdateDivWithContent","YourControllerName")'
    type: 'POST',
    data: {
        //some params to be passed to the controller
    },
    success: function (result) {
        //result is an html string of your customized partial view
        $("#yourDivId").html(result);
    }
});
于 2012-07-12T11:00:47.673 に答える