FineUIMvc随笔 - 动态创建表格列
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版。
《FineUIMvc随笔》目录
FineUIMvc随笔(3)不能忘却的回发(__doPostBack)
FineUIMvc随笔(6)对比WebForms和MVC中表格的数据库分页
FineUIMvc随笔(7)扩展通知对话框(显示多个不重叠)
...
用户需求

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

但是在 MVC 中,如果还想着 WebForms 的那一套,想着怎么才能在 Controller 中访问 View 中的表格控件,这是行不通的。
我曾写过一个系列文章《ASP.NET MVC快速入门(MVC5+EF6)》,开篇就讲到了 MVC 中的页面的生成流程:
这个页面之所以能够呈现在我们眼前,经历了三个主要流程:
- MVC的路由引擎根据URL查找相应的控制器(HomeController.cs)。
- 控制器的操作方法About准备数据,然后传入视图Home/About.cshtml。
- 视图准备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随笔 - 动态创建表格列的更多相关文章
- FineUIMvc随笔(1)动态创建表格列
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. <FineUIMvc随笔>目录 FineUIMvc随笔(1)动态创建表格列 FineUIMvc随笔(2)怎样在控件中 ...
- ASPxGridView动态创建表格列编辑模板
在项目中用到了DevExpress的ASPxGridview控件,每每去配置它的时候,总感觉很是啰嗦,于是想到了用代码自动配置. 于是有了这样的代码: foreach (ZiyuWeb.Entity. ...
- js/jq动态创建表格的行与列
之前做了一个项目,需求是能动态创建表格行,动态创建表格的列,度了很多资料,都没有动态创建列的插件,所以自己动手写了一个 需求大概是(下图) 1.动态添加一行.2.动态添加一列,3.删除行.4.删除列, ...
- javascript动态创建表格:新增、删除行和列
转载:http://www.cnblogs.com/pato/archive/2009/09/02/1559068.html 利用js来动态创建表格有两种格式,appendChild()和insert ...
- js动态创建表格,删除行列的小例子
js动态创建表格,删除行列的实例代码. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...
- jquery动态创建表格
1.代码实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
- 利用javascript动态创建表格
//说明:实现功能.原理上文相同.不过这次是利用已有的简单的方法创建行和列,并实现内容行鼠标移入变色功能! 效果图: /*两个方法 1. trNode table.insertRow(-1) ...
- js如何动态创建表格(两种方法)
js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...
- 第84天:jQuery动态创建表格
jQuery动态创建表格 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...
随机推荐
- nginx 判断访问文件或目录不存在rewrite
文件及目录匹配,其中:* -f和!-f用来判断是否存在文件* -d和!-d用来判断是否存在目录* -e和!-e用来判断是否存在文件或目录* -x和!-x用来判断文件是否可执行样例 : 判断访问的图片是 ...
- Objective-C中的面向对象编程
1.过程式编程实例,画出Shape数组中的图形: // // main.m // hello-obj // // Created by zhouyang on 16/4/4. // Copyright ...
- Spark中的wordCount程序实现
import org.apache.spark.SparkConf; import org.apache.spark.api.java.JavaPairRDD; import org.apache.s ...
- iOS 开发新版 动态库framework
0. 参考 http://www.cocoachina.com/industry/20140613/8810.html framework+xib参考 : http://blog.csdn.net/x ...
- MYSQL 函数复习
数学函数 ABS(X) 返回X的绝对值 SQRT(x) 返回非负数X的二次方根 MOD(x,y) 返回x被y除后的余数 CEIL(x) ...
- Repeated Substring Pattern Leetcode
Given a non-empty string check if it can be constructed by taking a substring of it and appending mu ...
- Win7 x64 Eclipse无法识别手机 / adb interface有黄色感叹号,无法识别
今天公司停电,因此把安卓项目带回宿舍做.宿舍的笔记本,装的是Win7 x64,手机连上电脑后,windows可以识别,但Eclipse的DDMS中却无法识别,什么都没有: 然后打开设备管理器查看,发现 ...
- 基于监听的事件处理——Activity本身作为事件监听器
这种形式使用Activity本身作为监听器类,可以直接在Activity类中定义事件处理方法,这种形式非常简洁.但这种做法有两个缺点: 这种形式可能造成程序结构混乱,Activity的主要职责应该是完 ...
- redhat6.4下安装Oracle11g
一.在Root用户下执行以下步骤: 1)修改用户的SHELL的限制,修改/etc/security/limits.conf文件 * soft nproc 2047 ...
- [linux]ngrep命令、常见用法
1.ngrep命令 ngrep命令是grep命令的网络版,ngrep用于搜寻指定的数据包(抓包.过滤).能识别TCP.UDP和ICMP包,理解bpf的过滤机制. 1.1 安装 brew install ...