Solved

Trying to manipulate the displayed value in a GridView column

Posted on 2009-07-01
2
280 Views
Last Modified: 2013-12-17
 I have a column I am creating in a GridView. Now the values retrived from the database for this column are integers.(1,2,3,4) I am trying to run a test for the integer retrieved and then manipulate the DataFormat string of the column based on the test. So if the value retrieved is 1, then write "Customer Complaint".
  However currently my tests (The switch case) do not seem to be running. Question becomes what column property do I actually need to test on as currently testing on the .DataField property does not seem to work. Running a test with a series of IF statements currently yields the same result. Any direction would be greatly appreciated.

Jason
BoundField correspondencetype_i = new BoundField();

        correspondencetype_i.HeaderText = "Correspondence Type";

        correspondencetype_i.DataField = "correspondencetype_i"
 

        switch (correspondencetype_i.DataField)

        {

            case "1":

                correspondencetype_i.DataFormatString = "Customer Complaint";

                break;
 

            case "2":

                correspondencetype_i.DataFormatString = "Technical Support";

                break;
 

            case "3":

                correspondencetype_i.DataFormatString = "Customer Suggestion";

                

                break;
 

            case "4":

                correspondencetype_i.DataFormatString = "Repair(RMA)";

                break;

        }

Open in new window

0
Comment
Question by:jazzcatone
2 Comments
 
LVL 22

Accepted Solution

by:
prairiedog earned 500 total points
ID: 24755068
Do you have to add the BoundField dynamically?
 
0
 
LVL 41

Expert Comment

by:guru_sami
ID: 24755289
You should add BoundField in your Markup and not in code-behind.
Then in your RowDataBound Event handler do something like below:

protected void GridView4_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            DataRowView dv = (DataRowView)e.Row.DataItem;
            string value = "";
            //yourColumnIndex below is the column in your record returned from DB that is being bound to this field
            int dbValue = Convert.ToInt32(dv.Row.ItemArray[yourColumnIndex])
            switch (dbValue )
            {
                case 1:
                    value = "Customer Complaint";
                    break;
                case 2:
                    value = "Technical Support";
                    break;
              //and so on
            }
            //yourColumnIndexToReplace is the column in the GV for which you want to replace the value.
            e.Row.Cells[yourColumnIndexToReplace].Text = value;
        }
    }
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Just a quick little trick I learned recently.  Now that I'm using jQuery with abandon in my asp.net applications, I have grown tired of the following syntax:      (CODE) I suppose it just offends my sense of decency to put inline VBScript on a…
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
Windows 10 is mostly good. However the one thing that annoys me is how many clicks you have to do to dial a VPN connection. You have to go to settings from the start menu, (2 clicks), Network and Internet (1 click), Click VPN (another click) then fi…

867 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now