DataGridView appearance

Hello all,
Be default, a data grid view which is presenting a data in two columns, has "three" columns. The first column (left-most) just shows an arrow head on the active row, and allows us to select rows, etc. Is there a way to hide this column?
Also, I was wondering of adding a column to the end with a "X" image in it, which, when clicked, deleted that row from the data grid view.
Please advice
Huji
LVL 14
hujiAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Éric MoreauSenior .Net ConsultantCommented:
Hi huji,

to hide a column, see http://msdn2.microsoft.com/en-gb/library/0c24a0d7(VS.80).aspx

Cheers!
0
SanclerCommented:
To hide the leftmost column, the one you are talking about, set the .RowHeadersVisible = False in the datagridview's property window.

As to the idea of the additional column at the end, I'm not sure what the question is.  Here's a link about adding columns

   http://msdn2.microsoft.com/en-us/library/dyyesckz(VS.80).aspx

and this is the sort of code you would need when your X image was clicked on
   
        Dim drv As DataRowView = BindingContext(myDataGridView.DataSource).Current
        drv.Delete()

Roger
0
hujiAuthor Commented:
Sancler, I want the datagird to appear like this:

name           surname            age
=============================
jack             smith                 13                 x
john             smith                 27                x

And pressing the x button should delete the row. It can be an image or a button, etc.
0
Build an E-Commerce Site with Angular 5

Learn how to build an E-Commerce site with Angular 5, a JavaScript framework used by developers to build web, desktop, and mobile applications.

SanclerCommented:
Code like this will add the column

        Dim dc As New DataGridViewButtonColumn
        dc.Text = "X"
        dc.UseColumnTextForButtonValue = True
        dc.HeaderText = "Delete"
        myDataGrid.Columns.Add(dc)

And code like this in the datagridview's Cell_Click event will do the deletion

        If e.ColumnIndex = 4 Then '<<< SEE NOTE BELOW
            Dim drv As DataRowView = BindingContext(dgvMain.DataSource).Current
            drv.Delete()
        End If

The 4 there is based on the pattern you used as an example.  You might have to alter it if there are more or less columns before the Delete column that has been added.  And I've included no refinements like checking if a header cell, or a new row cell, has been clicked.  But that's the idea.

Roger
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Visual Basic.NET

From novice to tech pro — start learning today.