声明: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 = ;
columns.Add(field); field = new RenderField();
field.HeaderText = "入学年份";
field.DataField = "EntranceYear";
field.FieldType = FieldType.Int;
field.Width = ;
columns.Add(field); RenderCheckField checkfield = new RenderCheckField();
checkfield.HeaderText = "是否在校";
checkfield.DataField = "AtSchool";
checkfield.RenderAsStaticField = true;
checkfield.Width = ;
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()
.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

FineUIMvc随笔(1)动态创建表格列的更多相关文章

  1. FineUIMvc随笔 - 动态创建表格列

    声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. 用户需求 用户希望实现动态创建表格列,在 WebForms 中,我们通过在 Page_Init 中创建列来实现: 但是在 MVC ...

  2. ASPxGridView动态创建表格列编辑模板

    在项目中用到了DevExpress的ASPxGridview控件,每每去配置它的时候,总感觉很是啰嗦,于是想到了用代码自动配置. 于是有了这样的代码: foreach (ZiyuWeb.Entity. ...

  3. js/jq动态创建表格的行与列

    之前做了一个项目,需求是能动态创建表格行,动态创建表格的列,度了很多资料,都没有动态创建列的插件,所以自己动手写了一个 需求大概是(下图) 1.动态添加一行.2.动态添加一列,3.删除行.4.删除列, ...

  4. javascript动态创建表格:新增、删除行和列

    转载:http://www.cnblogs.com/pato/archive/2009/09/02/1559068.html 利用js来动态创建表格有两种格式,appendChild()和insert ...

  5. js动态创建表格,删除行列的小例子

    js动态创建表格,删除行列的实例代码. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...

  6. jquery动态创建表格

    1.代码实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  7. 利用javascript动态创建表格

    //说明:实现功能.原理上文相同.不过这次是利用已有的简单的方法创建行和列,并实现内容行鼠标移入变色功能! 效果图: /*两个方法 1.  trNode  table.insertRow(-1)    ...

  8. js如何动态创建表格(两种方法)

    js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...

  9. 第84天:jQuery动态创建表格

    jQuery动态创建表格 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

随机推荐

  1. require.js简单入门

    推荐文章:http://www.ruanyifeng.com/blog/2012/11/require_js.html 1.以下例子主要实现功能, 1)引用jq库获取dom中元素文本, 2)实现并引用 ...

  2. JDK对CAS ABA问题解决-AtomicMarkableReference和AtomicStampedReference

    我们知道AtomicInteger和AtomicLong的原子操作,但是在这两个类在CAS操作的时候会遇到ABA问题,可能大家会疑问什么是ABA问题呢,请待我细细道来: ABA问题:简单讲就是多线程环 ...

  3. Postman:传递的参数是List类型时 传参格式的写法

    Postman传递的参数是List类型 实体类中引用了一个List,泛型为其他实体类 参数是List集合时,Postman中参数格式如下图所示: 有不明白的地方,欢迎留言

  4. git 建议使用

    1 登录github官网首页 创建一个项目 2 本地克隆下载git项目 git clone https://github.com/wangguoxingduanxuejing/branch-pract ...

  5. 从壹开始前后端分离 [.netCore 填坑 ] 三十四║Swagger:API多版本控制,带来的思考

    前言 大家周二好呀,.net core + Vue 这一系列基本就到这里差不多了,今天我又把整个系列的文章下边的全部评论看了一下(我是不是很负责哈哈),提到的问题基本都解决了,还有一些问题,已经在QQ ...

  6. qml demo分析(samegame-拼图游戏)

    一.效果展示 相信大家都玩儿过连连看游戏,而且此款游戏也是闲时一款打发时间的趣事,那么接下来我将分析一款类似的游戏,完全使用qml编写界面,复杂逻辑使用js完成.由于此游戏包含4种游戏模式,因此本篇文 ...

  7. MyWebViewDemo【封装Webview常用配置和选择文件、打开相机、录音、打开本地相册的用法】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 封装webview的常用配置和选择文件.打开相机.录音.打开本地相册的用法.[如果想要使用简单的预览功能,可以参考<MyBri ...

  8. 目录导航「深入浅出ASP.NET Core系列」

    希望给你3-5分钟的碎片化学习,可能是坐地铁.等公交,积少成多,水滴石穿,谢谢关注. 入门篇 引子 1.1专题介绍 1.2环境安装 1.3创建项目 1.4部署到IIS 1.5准备CentOS和Ngin ...

  9. JavaScript类型相关常用操作

    JS数组,字符串,json互相转换 JS数组转字符串 使用数组自带的join方法可以把数组转化为字符串: let arr = [1,2,'uu']; let str = arr.join(','); ...

  10. 玩转SpringBoot之定时任务详解

    序言 使用SpringBoot创建定时任务非常简单,目前主要有以下三种创建方式: 一.基于注解(@Scheduled) 二.基于接口(SchedulingConfigurer) 前者相信大家都很熟悉, ...