整理工作~

完整的代码在GitHub上, 路径:

项目背景:追踪某个issue,并且记录每天的状态。

要求:1、点击日期就能更改,并且用颜色标志不同的状态

    2、增加按钮可关闭issue

    3、布局要求日期横排放在追踪信息之后

刚拿到这简短干练的需求之后,有点懵,sample图都没有,都凭自己想象了。主要提需求的都是一群完全不懂开发的人,真的是完全、完全、完全不懂!!!怀念在软件公司的日子。。。。。。

大概想了一下,画了张类似下面截图的草图并且根据要求详细地写了一份Specification,一致通过之后,就开始准备写这个功能了。。。。

废话不多说,直接看图和代码吧~

效果图:

前台.aspx 代码比较简短,只绑定了一个不可见的ButtonField, 用于单元格单击事件

后台主要代码片断

重建表头在事件gvData_RowCreated里面

 switch (e.Row.RowType)
            {
                   case DataControlRowType.Header:
                    TableCellCollection tcHeader = e.Row.Cells;
                    tcHeader.Clear();
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxx.";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "xxxxx";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "Status";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "Remarks";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Text = "Month";
                    tcHeader.Add(new TableHeaderCell());
                    tcHeader[].Attributes.Add(");
                    tcHeader[].Text = "xxxx Data";

                    break;
            }

单击事件代码, 首先需要设置从哪一列开始可单击弹出框,然后在RowDataBound事件中允许单击并弹出框

  if (e.Row.RowType == DataControlRowType.DataRow)
            {
                LinkButton _singleClickButton = (LinkButton)e.Row.Cells[].Controls[];
                string _jsSingle = ClientScript.GetPostBackClientHyperlink(_singleClickButton, "");
                //add events to each editable cell
                for (int columnIndex = _firstEditCellIndex; columnIndex < e.Row.Cells.Count; columnIndex++)
                {
                    //add the column index as the event argument parameter
                    , columnIndex.ToString());
                    e.Row.Cells[columnIndex].Attributes["onclick"] = js;
                    e.Row.Cells[columnIndex].Attributes["style"] += "cursor:pointer;cursor:hand;";
                    e.Row.Cells[columnIndex].Attributes.Add("onclick", "openWin('" + requestNo + "','" + month + "','" + date + "');");

                }
            }

改变单元格背景色同样在RowDataBound中

 if (date.Contains("P"))
                        {
                            date = date.TrimEnd('P');
                            e.Row.Cells[columnIndex].BackColor = ColorTranslator.FromHtml("#525f6b");
                        }
                        if (date.Contains("Y"))
                        {
                            date = date.TrimEnd('Y');
                            e.Row.Cells[columnIndex].BackColor = ColorTranslator.FromHtml("#fac970");
                        }
                        if (date.Contains("L"))
                        {
                            date = date.TrimEnd('L');
                            e.Row.Cells[columnIndex].BackColor = ColorTranslator.FromHtml("#15a452");
                        }
                        if (date.Contains("R"))
                        {
                            date = date.TrimEnd('R');
                            e.Row.Cells[columnIndex].BackColor = Color.Red;
                        }
                        if (date.Contains("B"))
                        {
                            date = date.TrimEnd('B');
                            e.Row.Cells[columnIndex].BackColor = ColorTranslator.FromHtml("#004986");
                        }
                        e.Row.Cells[columnIndex].Text = date;

设置Status列为单击可关闭列,代码如下

   , .ToString());
   e.Row.Cells[].Attributes["onclick"] = editJs;
   e.Row.Cells[].Attributes["style"] += "cursor:pointer;cursor:hand;";
   ].Text == "Ongoing")
      e.Row.Cells[].Text = "<img  src='../Images/page_white_edit.png'/>";
   ].Text == "Closed")
      e.Row.Cells[].Text = "<img  src='../Images/accept-f.png'/>";
   e.Row.Cells[].Attributes.Add("onclick", "openCloseWin('" + requestNo + "');");

可能实现的方法不是很好,请多指教~

Gridview 重建表头/单击单元格弹出对话框/改变单元格背景色的更多相关文章

  1. qtableview 鼠标划过单元格弹出标签显示单元格内容

    QStandardItem *item = new QStandardItem(show_content); infoTableModel->setItem(1, 1, item); item- ...

  2. java selenium (十一) 操作弹出对话框

    Web 开发人员通常需要利用JavaScript弹出对话框来给用户一些信息提示, 包括以下几种类型 阅读目录 对话框类型 1.  警告框: 用于提示用户相关信息的验证结果, 错误或警告等 2. 提示框 ...

  3. dos命令弹出对话框---Msg命令详解

    标签: dos批处理对话框 2015-11-12 17:20 497人阅读 评论(0) 收藏 举报 脚本(30)  版权声明:本文为博主原创文章,未经博主允许不得转载. dos命令弹出对话框---Ms ...

  4. NET使用了UpdatePanel后如何弹出对话框!

    原文:NET使用了UpdatePanel后如何弹出对话框! 在ajax中的UpdatePanel弹出对话窗,可以使用: ScriptManager.RegisterStartupScript(Upda ...

  5. JavaScript中的三种弹出对话框

    学习过js的小伙伴会发现,我们在一些实例中用到了alert()方法.prompt()方法.prompt()方法,他们都是在屏幕上弹出一个对话框,并且在上面显示括号内的内容,使用这种方法使得页面的交互性 ...

  6. js弹出对话框的三种方式(转)

    原文地址:https://www.jb51.net/article/81376.htm javascript的三种对话框是通过调用window对象的三个方法alert(),confirm()和prom ...

  7. 02 - Unit06:弹出对话框

    弹出对话框 如何实现弹出 //弹出出对话框 $("#can").load("alert/alert_notebook.html"); //显示背景色 $(&qu ...

  8. [Firefox附加组件]0003.弹出对话框

    Firefox中使用面板(panel)模块来显示弹出对话框,面板的内容通过HTML编写.你可以在面板上运行content script,尽管在面板里的脚本无法直接访问插件代码,但是你可以在面板脚本和插 ...

  9. 10.JAVA之GUI编程弹出对话框Dialog

    在上节基础上添加对话框显示错误信息. 代码如下: /*弹出对话框显示错误信息,对话框一般不单独出现,一般依赖于窗体.*/ /*练习-列出指定目录内容*/ import java.awt.Button; ...

随机推荐

  1. jQuery实践-别踩白块儿网页版

    ▓▓▓▓▓▓ 大致介绍 终于结束了考试,放假回家了.这次的别踩白块儿网页版要比之前做的 jQuery实践-网页版2048小游戏 要简单一点,基本的思路都差不多. 预览:别踩白块网页版 这篇博客并不是详 ...

  2. 一个web应用的诞生--美化一下

    经过上一章的内容,其实就页面层来说已结可以很轻松的实现功能了,但是很明显美观上还有很大的欠缺,现在有一些很好的前端css框架,如AmazeUI,腾讯的WeUI等等,这里推荐一个和flask集成很好的b ...

  3. 消费创富会开发模式系统App

    消费创富会系统定制开发,消费创富会网页开发模式,消费创富会开发软件,消费创富会系统APP开发,消费创富会平台模式开发,专业开发微信商城分销.公排.全返.分红.互助等模式定制开发,APP.网页版.微信端 ...

  4. 工作总结之Git

    工作中,终端数据的制作好后,使用的是SmartGit(注:Git的一个客户端)来push到服务器:但是出现了奇怪的现象: 1.git checkout到本地的目录,理论上目录下有包括新增,删除,变更在 ...

  5. 02月刊(上) | 微信小程序

    * { margin: 0; padding: 0 } .con { width: 802px; margin: 0 auto; text-align: center; position: inher ...

  6. list_删除元素

    项目遇到了题目所述的问题,还是折腾了一会... 现在总结一下: 这里写一个测试小程序: List<Integer> ints = new ArrayList<Integer>( ...

  7. esri-leaflet入门教程(1)-leaflet介绍

    esri-leaflet入门教程(1)-esri leaflet介绍 by 李远祥 关于leaflet,可能很多人比较陌生,如果搭上esri几个字母,可能会有更多的人关注.如果没有留意过leaflet ...

  8. 地图学与GIS制图的基础理论(一)

    说到地图制作,很多人第一时间就会跟地图学进行挂钩.是的,地图学的很多理论和知道思想都非常适合基于GIS制图.可以说,利用GIS进行电子地图制作,其实也属于地图学的一小部分. 地图学是研究地图的理论.地 ...

  9. SQL2012还原数据库操作在本地服务器上操作和用别的电脑远程连接到服务器进行操作的文件路径差异

    在数据库服务器上想还原一个数据库到某个备份文件时期的,服务器的数据库文件本身是保存在 D:\DEVDB目录 通过开发电脑上的MS manager来连接数据库服务器操作还原 虽发现文件卡项上,原始文件名 ...

  10. uml系列(三)——用例图

    用例图是从用户的角度出发,描述系统功能的.在软件开发过程中,开发人员首先获知用户的需求,然后设计用例模型,在分析并设计系统来实现这些用例.在系统完成后,还要根据用例图来对系统进行验证. 用例图主要介绍 ...