开发者

asp.net GridView replace Checkboxes with Yes/No in Dynamic GridView

开发者 https://www.devze.com 2023-02-26 05:02 出处:网络
I have a gridview that displays the results of a custom query.The number of columns is unknown, and whether or not the DataTable being bound contains boolean columns is unknown.The title of columns th

I have a gridview that displays the results of a custom query. The number of columns is unknown, and whether or not the DataTable being bound contains boolean columns is unknown. The title of columns that will contain a boolean value is also unknown.

Without knowing that information beforehand, is there a way to开发者_如何学C be able to replace the checkboxes with a simple Yes/No ?

This seems quite straightforward with predefined columns, but not so much in this case.


I was able to come up with a solution not long after I posted the question. What I ended up doing is:

  • Create a clone the DataTable with each column of type string,
  • Iterate through each item array (object[]) to search for "True" and "False" and replace with "Yes" and "No", respectively,
  • Create a new DataRow, set its ItemArray property to the new object array, and add the new DataRow to the new DataTable.

Here is the code of how it was done:

        DataTable Clone = ResultsTable.Clone();
        for (int i = 0; i < Clone.Columns.Count; i++)
        {
            Clone.Columns[i].DataType = typeof(string);
        }

        foreach (DataRow row in ResultsTable.Rows)
        {
            DataRow r = null;
            object[] ItemArray = row.ItemArray;
            for (int i = 0; i< ItemArray.Length; i++)
            {
                if (ItemArray[i].ToString() == "True")   ItemArray[i] = "Yes";
                if (ItemArray[i].ToString() == "False")  ItemArray[i] = "No";
            }

            r = Clone.NewRow();
            r.ItemArray = ItemArray;
            Clone.Rows.Add(r);
        }

This concept should be applicable to similar DataTable textual transformations as well.

0

精彩评论

暂无评论...
验证码 换一张
取 消