• 让GridView在无数据时显示表头Header和脚注Footer


    因為GridView內建修改、刪除之功能,所以很多人利用GridView的Footer列,加入控制項,作為新增的功能。但因為GridView在沒有資料的時候,除了Empty Template外,不會顯示Header和Footer列,所以新增的功能就無效了。

    有人直接利用Empty Template,加入FormView或DetailView作為新增的功能,但我覺得畫面上的不一致,容易造成使用者的困擾,執意要找出利用Footer列的方式。為此用Google找了一個晚上和早上,再加上 try 了半天,終於讓我摸索出最佳答案了。

    方法是在GridView的PreRender事件中,判斷 Rows.Count 是否等於0,再執行下面這個函數。這樣利用Footer列做為新增資料的功能,就萬無一失了。

    不過在執行階段時,新增資料後自動重新整理本頁時,因為GridView的DataSource還是我們虛擬的DataTable,因此不會顯示新增的記錄,故需在GridView1_Load中加入一段,改回原本的SqlDataSource。

    public static void renderEmptyGridView(GridView EmptyGridView, string FieldNames)
    {
    //將GridView變成只有Header和Footer列,以及被隱藏的空白資料列
    DataTable dTable = new DataTable();
    char[] delimiterChars = {','};
    string[] colName = FieldNames.Split(delimiterChars);
    foreach (string myCol in colName)
    {
    DataColumn dColumn = new DataColumn(myCol.Trim());
    dTable.Columns.Add(dColumn);
    }
    DataRow dRow = dTable.NewRow();

    foreach (string myCol in colName)
    {
    dRow[myCol.Trim()] = DBNull.Value;
    }
    dTable.Rows.Add(dRow);

    EmptyGridView.DataSourceID = null;
    EmptyGridView.DataSource = dTable;
    EmptyGridView.DataBind();
    EmptyGridView.Rows[0].Visible = false;
    }
    protected void GridView1_PreRender(object sender, EventArgs e)
    {
    if (GridView1.Rows.Count == 0)
    {
    renderEmptyGridView(GridView1, "FLOW_UID, FLOW_CODE, FLOW_NAME, FLOW_TYPE");
    }

    }

    protected void GridView1_Load(object sender, EventArgs e)
    {
    //回復原本GridView的資料連結
    GridView1.DataSource = null;
    GridView1.DataSourceID = "SqlDataSource1";
    }

  • 相关阅读:
    andorid 平台调用Web Service , 图片传输
    android 中在CMD中查看sqlite
    Click ListView Item跳转Activity
    C# 中几个小“陷阱”
    Xamarin 手动安装步骤+破解(最新版Xamarin V3)
    语音播报实时天气
    手动创建VS单元测试,显示代码覆盖率
    Ubuntu 12.10 配置MyEclipes 10.7环境(加破解)
    C#对象赋值出现的诡异问题,或许你也遇到过,有待你的解决
    jquery 小插件,完成“输入字段预期值的提示信息”,防html5 placeholder属性
  • 原文地址:https://www.cnblogs.com/ninepts/p/2166052.html
Copyright © 2020-2023  润新知