FineUIMvc随笔(1)动态创建表格列

声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版。

 

《FineUIMvc随笔》目录

FineUIMvc随笔(1)动态创建表格列

FineUIMvc随笔(2)怎样在控件中嵌套 HTML

FineUIMvc随笔(3)不能忘却的回发(__doPostBack)

FineUIMvc随笔(4)自定义回发参数与自定义回发

FineUIMvc随笔(5)UIHelper是个什么梗?

FineUIMvc随笔(6)对比WebForms和MVC中表格的数据库分页

FineUIMvc随笔(7)扩展通知对话框(显示多个不重叠)

...

 

 

 

 

 

用户需求

 

用户希望实现动态创建表格列,在 WebForms 中,我们通过在 Page_Init 中创建列来实现:

 

但是在 MVC 中,如果还想着 WebForms 的那一套,想着怎么才能在 Controller 中访问 View 中的表格控件,这是行不通的。

 

我曾写过一个系列文章《ASP.NET MVC快速入门(MVC5+EF6)》,开篇就讲到了 MVC 中的页面的生成流程:

这个页面之所以能够呈现在我们眼前,经历了三个主要流程:

  1. MVC的路由引擎根据URL查找相应的控制器(HomeController.cs)。
  2. 控制器的操作方法About准备数据,然后传入视图Home/About.cshtml。
  3. 视图准备HTML片段,放入布局页面并返回浏览器。

 

控制器准备数据,传入视图,然后视图才开始渲染页面。也就是说控制器执行时,对视图的内容一无所知。理解这一点很重要。

 

动态创建表格列

当然在 MVC 中实现动态创建表格列也不难,我们需要将表格列数据(GridColumn[])像表格数据源一样传递给视图即可。

 

控制器:

// GET: Grid/DynamicColumns
public ActionResult Index()
{
    InitGridColumns();

    return View(DataSourceUtil.GetDataTable());
}

private void InitGridColumns()
{
    List<GridColumn> columns = new List<GridColumn>();

    RenderField field = null;

    columns.Add(new RowNumberField());

    field = new RenderField();
    field.HeaderText = "性别";
    field.DataField = "Gender";
    field.FieldType = FieldType.Int;
    field.RendererFunction = "renderGender";
    field.Width = 80;
    columns.Add(field);

    field = new RenderField();
    field.HeaderText = "入学年份";
    field.DataField = "EntranceYear";
    field.FieldType = FieldType.Int;
    field.Width = 100;
    columns.Add(field);

    RenderCheckField checkfield = new RenderCheckField();
    checkfield.HeaderText = "是否在校";
    checkfield.DataField = "AtSchool";
    checkfield.RenderAsStaticField = true;
    checkfield.Width = 100;
    columns.Add(checkfield);

    // ...

    ViewBag.Grid1Columns = columns.ToArray();
}

 

在控制器中,动态创建 List<GridColumn> 对象,并保存到 ViewBag.Grid1Columns。

实际项目中,这一步可能需要和数据库交互,来获取需要动态创建的表格列。

 

视图:

@{
    ViewBag.Title = "Grid/Grid";
    var F = @Html.F();
}

@model System.Data.DataTable

@section body {

    @(F.Grid()
        .EnableCollapse(true)
        .Width(850)
        .Title("表格(动态创建列)")
        .ShowHeader(true)
        .ShowBorder(true)
        .ID("Grid1")
        .DataIDField("Id")
        .DataTextField("Name")
        .Columns(ViewBag.Grid1Columns)
        .DataSource(Model)
    )
    <br>
    <br>

    @(F.Button()
        .Text("选中了哪些行")
        .ID("Button1")
        .Listener("click", "notifySelectedRows('Grid1');")
    )

}

 

页面效果:

 

小结

本篇文章介绍了 WebForms 和 MVC 中动态创建表格列的方法。通过对比,也希望大家能充分了解两种框架的重要区别。

 

如果你刚开始接触 MVC,建议先从三石的系列教程开始:http://www.cnblogs.com/sanshi/p/6210695.html

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mathcad 是一种功能强大的数学软件,它可以让我们非常方便地进行数学计算和分析。学习使用Mathcad 对我来说是一种挑战,但同时也是一次非常有意义的经历。 首先,通过学习Mathcad,我深刻认识到数学公式和计算的重要性。在过去,我常常依赖计算器和纸笔进行数学计算,但这种方式往往效率不高,并且难以避免出错。而Mathcad 提供了一个直观且可视化的界面,让我们可以更加直观地理解和应用数学原理。 其次,学习Mathcad 也提高了我的数学建模和问题解决能力。在学习过程中,我发现Mathcad 的强大之处在于它能够将数学公式和实际问题相结合。通过输入不同的数学公式和数据,我可以揭示和解决一些实际世界中的问题,例如电路分析、力学运动、概率统计等,这为我提供了宝贵的数学建模实践经验。 此外,通过学习Mathcad,我也掌握了一种全新的数学表达方式。通过使用Mathcad的函数和符号库,我可以更加准确地表达数学概念和计算过程。这种表达方式简洁明了,易于理解和阅读,有助于提高我的数学思维能力和表达能力。 尽管学习Mathcad可能会遇到一些挑战,例如复杂的函数和符号操作,对于初学者来说不太友好,但通过不断实践和学习,我相信我可以克服这些问题,并不断进步。 总的来说,学习Mathcad 是一次充满挑战和收获的过程。它帮助我提高了数学知识和技能,提升了我的数学建模和问题解决能力。我相信在未来的学习和工作中,Mathcad 将成为我强大的数学工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值