DevExpress PopupControl内置GridView模式编辑表单

时间:2014-01-04 12:06:40

标签: asp.net-mvc gridview devexpress

我在gridview的模态编辑窗体中遇到弹出控件的问题。 问题是:当我点击模态表单上下文区域时,弹出控件不会隐藏!它只是重新排序。 请先查看attached movie,然后阅读代码 感谢。

这是我的代码:

MODEL:

public class Student
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Family { get; set; }
    public int Avg { get; set; }
}  

CONTROLLER:

public class HomeController : Controller
{
    public ActionResult Index()
    {
            Session["Students"] = new List<Student>() 
                                        { 
                                            new Student { Id = 1, Name = "N1", Family = "f1", Avg = 1 } ,
                                            new Student { Id = 2, Name = "N2", Family = "f2", Avg = 2 } ,
                                            new Student { Id = 3, Name = "N3", Family = "f3", Avg = 3 } ,
                                            new Student { Id = 4, Name = "N4", Family = "f4", Avg = 4 } ,
                                        };
        return View(Session["Students"]);
    }

    public ActionResult PartialGridView(Student student)
    {
        return PartialView("Index", Session["Students"]);
    }
}  

查看

@model List<Test.Models.Student>

@Html.DevExpress().GridView(settings =>
{
  settings.Name = "GvStudent";

  settings.KeyFieldName = "Id";
  settings.CallbackRouteValues = new { Controller = "Home", Action = "PartialGridView" };
  settings.SettingsEditing.AddNewRowRouteValues = new { Controller = "Home", Action = "AddStudentPartialGridView" };
  settings.SettingsEditing.UpdateRowRouteValues = new { Controller = "Home", Action = "UpdateStudentPartialGridView" };
  settings.SettingsEditing.DeleteRowRouteValues = new { Controller = "Home", Action = "DeleteStudentPartialGridView" };

  settings.SettingsEditing.Mode = GridViewEditingMode.PopupEditForm;
  settings.SettingsPopup.EditForm.Modal = true;
  settings.SettingsPopup.EditForm.HorizontalAlign = PopupHorizontalAlign.WindowCenter;
  settings.SettingsPopup.EditForm.VerticalAlign = PopupVerticalAlign.WindowCenter;
  settings.SettingsPopup.EditForm.Width = 400;
  settings.SettingsPopup.EditForm.Height = 200;
  settings.SettingsText.PopupEditFormCaption = "Student";

  settings.CommandColumn.Visible = true;

  settings.CommandColumn.NewButton.Visible = true;
  settings.CommandColumn.EditButton.Visible = true;
  settings.CommandColumn.DeleteButton.Visible = true;

  settings.Columns.Add(Name =>
  {
      Name.FieldName = "Name";
  });

  settings.Columns.Add(Family =>
  {
      Family.FieldName = "Family";
  });

  settings.Columns.Add(Avg =>
  {
      Avg.FieldName = "Avg";
  });

  settings.SetEditFormTemplateContent(content =>
  {
      Html.DevExpress().Button(btnShow =>
      {
          btnShow.Name="btnShow";
          btnShow.ClientSideEvents.Click = "function(s, e){popupControl.ShowAtElement(document.getElementById(s.name));}";
      }).Render();
  });

}).Bind(Model).GetHtml()

@{
  @Html.DevExpress().PopupControl(settings =>
  {
    settings.Name = "popupControl";
    settings.CloseAction = CloseAction.OuterMouseClick;
    settings.PopupVerticalAlign = PopupVerticalAlign.Below;
    settings.PopupHorizontalAlign = PopupHorizontalAlign.LeftSides;
    settings.ShowHeader = false;
    settings.ShowFooter = false;
    settings.AllowDragging = false;
    settings.AutoUpdatePosition = true;
    settings.Width = 320;

    settings.SetContent(() =>
    {
        ViewContext.Writer.Write("hello world!");
    });
  }).GetHtml();
}

0 个答案:

没有答案