之前我们的项目在前台显示只需要把数据从数据库读出来进行显示就可以,datagrid的表头字段都是写死的,把数据往表里一扔,就基本没什么事儿了,结果客户前几天要求,其中一个字段不能是死的,应该是有多少项显示多少项,比如说,原来只需要显示:其他项总分,现在需要显示的则是:xx加分,xx加分,xx减分,xx加分。。。。字段不固定,有多少项也不确定,需要从数据库中查到相应的字段来进行显示。

不能要求客户来适应咱们的系统啊,而应该全心全意为客户着想,所以,开始改。原来的情况是,所有的字段都是固定的,而且要显示的字段是跟数据库中某张表对应的,只需要查出来就可以。现在的情况是,其中一部分字段是固定的,另一部分字段是不固定的,然后固定字段的数据是从原来的表中查出来的,不固定字段的数据是从另外一张表查出来的。

经过一下午和一晚上的努力,终于初步完成了显示效果,但是还有缺点就是没办法做到分页显示,现在的效果还需要进一步优化,先把当前完成的部分记录一下。

代码如下:

view端:

//datagrid动态加载列
function getjson()
{
$.getJSON('/QueryScores/QueryOtherAssess', null, function (otherscores) {
var columns = new Array();
var column2 = {
field: '教工号', title: '教工号', width: 50
}
columns.push(column2);
var column3 = { field: '教职工姓名', title: '教职工姓名' }
columns.push(column3);
var column4 = { field: '工作效率', title: '工作效率', width: 50 }
columns.push(column4);
var column5 = { field: '职业道德', title: '职业道德', width: 50 }
columns.push(column5);
var column6 = { field: '业务能力', title: '业务能力', width: 50 }
columns.push(column6);
var column7 = { field: '廉洁自律', title: '廉洁自律', width: 50 }
columns.push(column7);
var column8 = { field: '工作成绩', title: '工作成绩', width: 50 }
columns.push(column8);
//导入其他分值的循环
for (var i = 0; i < otherscores.sum; i++) {
var column1={
field:otherscores.OtherScoresAssess[i],title:otherscores.OtherScoresAssess[i],width:70
}
columns.push(column1);
}
var column9 = { field: '总分', title: '总分', width: 50 }
columns.push(column9);
initTable(columns);
})
} function initTable(columns) {
$('#tt').datagrid({
title: '查看成绩',
url: '/QueryScores/QueryScoresIndex',
width: '100%',
rownumbers: true,
columns: [
columns
]
});
}

view端调了controller端两个方法,QueryOtherAssess是为了读取到需要动态加载的列的表头字段。QueryScoresIndex是将数据查到返回的方法。

QueryOtherAssess:

public ActionResult QueryOtherAssess()
{
IList<string> OtherScoresAssess = OtherScoresAsscssProgramBLL.LoadEnities(u => u.IsUsed == true).Select(u => u.AsscssProgram).ToArray(); var OtherScoresAssessList = new
{
sum = OtherScoresAssess.Count(),
OtherScoresAssess = OtherScoresAssess
}; return Json(OtherScoresAssessList, JsonRequestBehavior.AllowGet); }

QueryScoresIndex首先将数据查出来,然后转成json字符串返回前台。

具体查数据就不贴了,看一下赋值的段落:

 //表头
DataTable FinalTable = new DataTable();
FinalTable.Columns.Add("教工号", typeof(int));
FinalTable.Columns.Add("教职工姓名", typeof(string));
FinalTable.Columns.Add("工作效率", typeof(string));
FinalTable.Columns.Add("职业道德", typeof(string));
FinalTable.Columns.Add("业务能力", typeof(string));
FinalTable.Columns.Add("廉洁自律", typeof(string));
FinalTable.Columns.Add("工作成绩", typeof(string));
for (int i = 0; i < YzOtherProgramEntity.Count; i++)
{
FinalTable.Columns.Add(YzOtherProgramEntity[i].AsscssProgram, typeof(string));
}
FinalTable.Columns.Add("总分", typeof(string));

然后是赋值:

 DataRow FileRow = FinalTable.NewRow();
FileRow["教工号"] = scoresstaffid;
FileRow["教职工姓名"] = staffname;
FileRow["工作效率"] = staffscoresEntity[i].WorkEfficiency;
FileRow["职业道德"] = staffscoresEntity[i].ProfessionalEthics;
FileRow["业务能力"] = staffscoresEntity[i].BusinessAbility;
FileRow["廉洁自律"] = staffscoresEntity[i].HonestyDiscipline;
FileRow["工作成绩"] = staffscoresEntity[i].WorkPerformance; if (YzOtherProgramEntity != null)
{
for (int j = 0; j < YzOtherProgramEntity.Count; j++)
{
Decimal othertotalscores = 0;
Guid otherprogramEntityID = YzOtherProgramEntity[j].ID;
IList<YzOtherScoresEntity> YzOtherScoresEntity = OtherScoresBLL.LoadEnities(u => u.CriticID == staffguid && u.Program == otherprogramEntityID && u.IsUsed == true).ToArray(); for (int k = 0; k < YzOtherScoresEntity.Count; k++)
{
othertotalscores = othertotalscores + YzOtherScoresEntity[k].Number;
} FileRow[YzOtherProgramEntity[j].AsscssProgram] = othertotalscores; } FileRow["总分"] = staffscoresEntity[i].TotalScores;
FinalTable.Rows.Add(FileRow);

最后转json字符串:

char[] specialChars = new char[] { ',' };
string JSONstring = "["; int index = 0;
foreach (DataRow dr in FinalTable.Rows)
{
JSONstring += "{"; foreach (DataColumn dc in FinalTable.Columns)
{
JSONstring += "\"" + dc.ColumnName + "\":\"" + dr[dc].ToString() + "\",";
}
JSONstring = JSONstring.TrimEnd(specialChars);
JSONstring += "},"; index++;
}
JSONstring = JSONstring.TrimEnd(specialChars);
JSONstring += "]";
return JSONstring;

然后前台进行接收,最后就可以做到动态加载列啦

结果:

【datagrid】动态加载列 2016-01-03 16:32 2013人阅读 评论(19) 收藏的更多相关文章

  1. hdu1171 Big Event in HDU(01背包) 2016-05-28 16:32 75人阅读 评论(0) 收藏

    Big Event in HDU Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  2. jquery easyui datagrid 动态 加载列

    实现方式: 首先根据输入的sql语句获得相关的列名称返回给前台,然后在datagrid中动态加载列,接着根据查询条件(包括sql语句)获取相关的记录返回给前台用于填充datagrid.从而实现类似or ...

  3. JAVA 对象数组,加载图片实例 分类: Java Game 2014-08-14 16:57 80人阅读 评论(0) 收藏

    主函数: package com.mywork; import java.awt.Color; import java.awt.Image; import javax.swing.ImageIcon; ...

  4. winform 解决界面闪动、提升加载速度 分类: WinForm 2015-02-03 16:34 161人阅读 评论(0) 收藏

    说明: 从一个技术交流群里获得,经验证效果不错. //作用 加快界面加载 protected override CreateParams CreateParams          {         ...

  5. EasyUI datagrid动态加载json数据

    最近做一个项目,要求是两张张表可能查找出10多种不同的结果集. 如果想只用一个表格就把全部的结果不同的显示出来那么就肯定不同使用固定的字段名字,要通过动态加载后台返回来的数据把它显示出来就必须动态加载 ...

  6. 百度地图-省市县联动加载地图 分类: Demo JavaScript 2015-04-26 13:08 530人阅读 评论(0) 收藏

    在平常项目中,我们会遇到这样的业务场景: 客户希望把自己的门店绘制在百度地图上,通过省.市.区的选择,然后加载不同区域下的店铺位置. 先看看效果图吧: 实现思路: 第一步:整理行政区域表: 要实现通过 ...

  7. 【第一篇】说说MVC+EF easyui dataGrid 动态加载分页表格

    首先上javascript的代码 <script type="text/javascript"> $(function () { LoadGrid(); }) //加载 ...

  8. 转 -- MVC+EF easyui dataGrid 动态加载分页表格

    首先上javascript的代码 <script type="text/javascript"> $(function () { LoadGrid(); }) //加载 ...

  9. easyui datagrid 动态加载数据 渲染问题,表格错位问题

    $('#dg').datagrid({ url:'datagrid_data.json', columns:[[ {field:'code',title:'Code',width:100}, {fie ...

随机推荐

  1. 通过游戏学python 3.6 第一季 第六章 实例项目 猜数字游戏--核心代码--猜测次数--随机函数和屏蔽错误代码--优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改 可复制直接使用 娱乐 可封装 函数

    #猜数字--核心代码--猜测次数--随机函数和屏蔽错误代码---优化代码及注释--简单账号密码登陆--账号的注册查询和密码的找回修改 #猜数字--核心代码--猜测次数--随机函数和屏蔽错误代码---优 ...

  2. jquery ajax跨越

    JSONP是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问 1.jsonp之$.ajax js $.ajax({ ...

  3. Linq 之 Where操作

    适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句. Where操作包括3种形式,分别为简单形式.关系条件形式 ...

  4. 码云及git使用

    首次使用码云,将本地文件与之关联(创建仓库之后的页面截图) git -- 版本控制(协同开发软件) git add . # 将当前文件下所有内容添加到临时缓存区 git commit -m " ...

  5. netbeans调试webapp 只能用localhost访问

    etbeans 我的电脑是192.168.0.2,用这个地址访问 网上有人说,分两种情况 此问题分两种情况: 1. 可以用127.0.0.1访问 2. 不能用127.0.0.1访问 针对第一种情况,我 ...

  6. mysql5 msi安装版

    有安装版为啥要用解压版? 搞不懂为啥大佬们都喜欢解压版? http://ftp.ntu.edu.tw/MySQL/Downloads/MySQLInstaller/mysql-installer-co ...

  7. 2019.8.13 NOIP模拟测试19 反思总结

    最早写博客的一次∑ 听说等会儿还要考试[真就两天三考啊],教练催我们写博客… 大约是出题最友好的一次[虽然我还是炸了],并且数据也非常水…忽视第三题的锅的话的确可以这么说.但是T3数据出锅就是你的错了 ...

  8. Leetcode49. Group Anagrams字母异位词分组

    给定一个字符串数组,将字母异位词组合在一起.字母异位词指字母相同,但排列不同的字符串. 示例: 输入: ["eat", "tea", "tan&quo ...

  9. composer本地安装文档 - CSDN博客

    1.下载下图2个文件 2.将上图2个文件放到php根目录下与php.exe再同一目录 3.在composer.bat写 4.配置环境变量(将php目录复制到环境变量里) 5.将php.ini配置文件的 ...

  10. git pull 总提示让输入merge 信息

    在生产环境拉去代码的时候,总是出现了 .git/MERGE_MSG,很烦. 虽然每次可以通过输入 :q 命令,取消,然后完成拉取.但是这样就很影响效率.解决办法一: 欺骗自己法只要我没看见这个问题,这 ...