asp.net使用原生控件实现自定义列导出功能的方法

 更新时间:2022年01月23日 09:20:40   作者:小恶魔P  
这篇文章主要给大家介绍了关于asp.net使用原生控件实现自定义列导出功能的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

自定义列实现

最近负责开发公司内部使用的人事信息化系统时,有一个需求是这样的,需要在页面中可以用户每次导出Excel时自定义需要导出哪些列,经过半天的琢磨和倒腾,总算完成了这个需求。写篇blog记录一下小菜鸡的成长历程。哈哈哈。

需求见截图所示:

tbg:数据源使用DataTable、且GridView中用于绑定数据的BoundFiled列中使用的DataField全部是与CheckBox中的ID一一对应,这样方便后面循环这些控件时进行操作。

尝试一

  • 数据源使用的是DataTable一开始想的是根据CheckBox的选中决定删除Remove掉DataTable中的列,因为每次查询时,DataTable中的数据会重新被填充,但在实施过程中发现,如果DataTable中的对应列移除掉,但是GridView中的列乜有移除的话,也会报错,想过也去移除对应的GridView中的BoundFiled,但是在移除后又去添加与CheckBox的ID相对应的列,如此操作非常容易出错,而且整个for循环写的非常恶心,一层套一层。而且在移除对应的DataTable列和GridView中的列之后会无法再进行有效的添加(前端不显示),猜测可能是回发问题导致的,没有有效解决遂放弃。

尝试二

  • 使用一个字典Dictionary存储CheckBox的ID和对应的选中状态,然后去遍历GridView中的每一列,为每一列设置对应的隐藏和显示状态。这个方案尝试成功了哈,哈哈哈,虽然很简单,但开心了好一阵子。下面放代码;
            DataTable dt = employeesServices.GetEmployeesDataTable();
            Dictionary<string, bool> ckbInfoList = new Dictionary<string, bool>();
            foreach (var control in Page.Controls)
            {
                if (control.GetType().ToString() == "System.Web.UI.HtmlControls.HtmlForm")
                {
                    HtmlForm form = (HtmlForm)control;
                    foreach (var item in form.Controls)
                    {
                        if (item is CheckBox)
                        {
                            CheckBox ckb = (CheckBox)item;
                            if (!ckb.Checked)
                            {
                                ckbInfoList.Add(ckb.ID, false);
                            }
                            else
                            {
                                ckbInfoList.Add(ckb.ID,true);
                            }
                        }
                    }
                }
            }
            //遍历GridView列,根据Dictionary提供的内容来决定是否隐藏。
            foreach (var control in Page.Controls)
            {
                if (control.GetType().ToString() == "System.Web.UI.HtmlControls.HtmlForm")
                {
                    HtmlForm form = (HtmlForm)control;
                    foreach (var item in form.Controls)
                    {
                        if (item.GetType().ToString() == "System.Web.UI.WebControls.GridView")
                        {
                            GridView gridView = (GridView)item;
                            foreach (BoundField col in gridView.Columns)
                            {
                                foreach (var keyValue in ckbInfoList)
                                {
                                    if (keyValue.Key == col.DataField)
                                    {
                                        col.Visible = Convert.ToBoolean(keyValue.Value);
                                    }
                                }
                            }
                        }
                    }
                }
            }
            gv.DataSource = dt;
            gv.DataBind();

总结

到此这篇关于asp.net使用原生控件实现自定义列导出功能的文章就介绍到这了,更多相关asp.net原生控件自定义列导出内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • js获取Treeview选中的节点(C#选中CheckBox项)

    js获取Treeview选中的节点(C#选中CheckBox项)

    方法网上有很多,试了一下都有瑕疵,于是设置断点调试,各个属性查找有用的字段,终于找到,接下来与大家分享解决方法,需要了解的朋友可以参考下
    2012-12-12
  • .NET的DateTime函数获取上个月的起始和截止时间的方法

    .NET的DateTime函数获取上个月的起始和截止时间的方法

    这篇文章主要介绍了NET的DateTime函数获取上个月的起始和截止时间的方法,可广泛使用于报表中的时间自动选择功能,是非常实用的技巧,需要的朋友可以参考下
    2015-01-01
  • VS初始化命令 ASP.NET常用技巧

    VS初始化命令 ASP.NET常用技巧

    此命令会运行几分钟时间,与此同时,Visual Studio 清除设置并将其自身重置到其最初的状态。
    2011-03-03
  • jQuery实现金额录入框

    jQuery实现金额录入框

    前端开发过程中,通常会用到数值录入框,比如要求输入金额,禁止录入非数值字符,也禁止粘贴非数值字符,本文主要对其实现方法进行介绍,需要的朋友一起来看下吧
    2016-12-12
  • ASP.NET Core 奇淫技巧之伪属性注入的实现

    ASP.NET Core 奇淫技巧之伪属性注入的实现

    这篇文章主要介绍了ASP.NET Core 奇淫技巧之伪属性注入的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • asp.net使用DataTable构造Json字符串的方法

    asp.net使用DataTable构造Json字符串的方法

    这篇文章主要介绍了asp.net使用DataTable构造Json字符串的方法,涉及asp.net字符串序列化、遍历及构造等操作技巧,需要的朋友可以参考下
    2015-12-12
  • asp.net core利用AccessControlHelper实现控制访问权限

    asp.net core利用AccessControlHelper实现控制访问权限

    这篇文章主要给大家介绍了关于asp.net core利用AccessControlHelper实现控制访问权限的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用asp.net core具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10
  • asp.net webservice返回json的方法

    asp.net webservice返回json的方法

    webservice默认的返回为XML 要返回json可以用json工具类把对象转为json字符串,需要的朋友可以参考下
    2014-02-02
  • C# 解析 RAS文件 SUM 光栅文件图象的代码

    C# 解析 RAS文件 SUM 光栅文件图象的代码

    C#解析RAS文件(SUM 光栅文件图象) 我只实现了24位色和8位色 这个结构也太简单了。只有文件头和数据区 。
    2010-03-03
  • ASP.NET 广告控件AdRotator的使用方法与实例

    ASP.NET 广告控件AdRotator的使用方法与实例

    广告控件是asp.net中一个独有的东西,他可以利用asp.net来生成广告控件所需的xml文档,然后再利用AdRotator来调用广告xml文件,根据我们的参考进行显示
    2013-08-08

最新评论