473,373 Members | 1,593 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,373 software developers and data experts.

Confirmation on a Delete button contained in a WebControls DataGri

Hello, I am developing a web form that contains some buttons and a data grid
which has as its last column link buttons that will delete the data
associated
with that row. Everything works fine, but users have requested a
confirmation
message pop up so the user can confirm the delete. I can not quite get
this to
work. Here are the facts:

I am working in the Microsoft Development Environment 2003 (Version
7.1.3088) and Microsoft .Net Framework 1.1 (Version 1.1.4322).

I have the following controls on the form
Protected WithEvents btnNewTrainingRoom As
System.Web.UI.WebControls.LinkButton
Protected WithEvents dgTrainingRooms As System.Web.UI.WebControls.DataGrid

The data grid has four coulumns: first is hidden column, columns 2 and 3
have
linkbuttons denoted as Select and a fourth column with a linkbutton denoted as
a delete (per the property builder screen). On the property builder screen
the
select buttons have button types of linkbutton and a command name of select.
The delete button has a button type of linkbutton and a command name of
delete.

I found a solution for adding a confirmation request on a web site. It
works
like this (note this is not the button where I want this action, I am only
testing)

btnNewTrainingRoom.Attributes.Add("onclick", "return confirm('Delete
selected contact?');")

The above code was tested on the btnNewTrainingRoom button and it does
everything
I am looking for. Now the problem is getting the .Attributes.Add associated
with the
delete buttons in my data grid.

Adding this code will allow me to add the "onclick" attribute to all of the
controls
Dim junk As DataGridItem
Dim junk2 As System.Web.UI.Control
For Each junk In dgTrainingRooms.Items ' Iterate through elements.
junk.Attributes.Add("onclick", "return confirm('Delete selected
contact?');")
Next

The confirmation works great, but for every button in the grid including
the
select buttons (which is not good). I only need to nest the .Attributes.Add
code in an IF/END IF block. My problem is that I can not figure out a general
way to determine when I have "delete" linkbutton as opposed to a "select"
linkbutton based on the properties available at that point in time. I have
spent the last two days researching the data members to figure this out, but
nothing has worked. Hopefully, it is just something I am overlooking.
Nov 18 '05 #1
3 2763

All you need to do is reference each cell control by column with something
like this in the ItemCreated event

' Cells[0] points to the first column, Cells[1] would point
to the second...
' therefore make sure this indexes your relevant delete
button column

LinkButton deleteButton =
DirectCast(e.Item.Cells[0].Controls[0], LinkButton)
deleteButton.Attributes.Add ( "onclick", "return
confirm('Delete selected contact?');

Note that it's not in the Page_Load event, so there's no need to parse
through each control. Asp.Net's doing that already when it's creating the
client side webpage, so you may has well hook into that event.

I've not tried the above, so it may need tweaking, any probs let me know.

Thanks.

Daniel.

"vcornjamb" <vc*******@discussions.microsoft.com> wrote in message
news:FE**********************************@microsof t.com...
Hello, I am developing a web form that contains some buttons and a data
grid
which has as its last column link buttons that will delete the data
associated
with that row. Everything works fine, but users have requested a
confirmation
message pop up so the user can confirm the delete. I can not quite get
this to
work. Here are the facts:

I am working in the Microsoft Development Environment 2003 (Version
7.1.3088) and Microsoft .Net Framework 1.1 (Version 1.1.4322).

I have the following controls on the form
Protected WithEvents btnNewTrainingRoom As
System.Web.UI.WebControls.LinkButton
Protected WithEvents dgTrainingRooms As System.Web.UI.WebControls.DataGrid

The data grid has four coulumns: first is hidden column, columns 2 and 3
have
linkbuttons denoted as Select and a fourth column with a linkbutton
denoted as
a delete (per the property builder screen). On the property builder
screen
the
select buttons have button types of linkbutton and a command name of
select.
The delete button has a button type of linkbutton and a command name of
delete.

I found a solution for adding a confirmation request on a web site. It
works
like this (note this is not the button where I want this action, I am only
testing)

btnNewTrainingRoom.Attributes.Add("onclick", "return confirm('Delete
selected contact?');")

The above code was tested on the btnNewTrainingRoom button and it does
everything
I am looking for. Now the problem is getting the .Attributes.Add
associated
with the
delete buttons in my data grid.

Adding this code will allow me to add the "onclick" attribute to all of
the
controls
Dim junk As DataGridItem
Dim junk2 As System.Web.UI.Control
For Each junk In dgTrainingRooms.Items ' Iterate through elements.
junk.Attributes.Add("onclick", "return confirm('Delete selected
contact?');")
Next

The confirmation works great, but for every button in the grid including
the
select buttons (which is not good). I only need to nest the
.Attributes.Add
code in an IF/END IF block. My problem is that I can not figure out a
general
way to determine when I have "delete" linkbutton as opposed to a "select"
linkbutton based on the properties available at that point in time. I
have
spent the last two days researching the data members to figure this out,
but
nothing has worked. Hopefully, it is just something I am overlooking.

Nov 18 '05 #2
Dan, thanks the code example was helpful. I got it to work. However, when
I run the page in the production environment with a fair number of records,
the page loads very slowly. I placed the code in the ItemCreated event
method for the data grid. It looks like the code is run for every row
created, thus the attribute.add is done multiple times. Is this correct?

Is there a way to add the attribute to the underlying delete linkbutton so
it is only done once? I can't figure out how to access the underlying
linkbutton and not each of the individual instances. Tried to see want was
available during the datagrid's load and init events, but could not figure
out a workable solution.

Thanks for your help.

"Dan Bass" wrote:

All you need to do is reference each cell control by column with something
like this in the ItemCreated event

' Cells[0] points to the first column, Cells[1] would point
to the second...
' therefore make sure this indexes your relevant delete
button column

LinkButton deleteButton =
DirectCast(e.Item.Cells[0].Controls[0], LinkButton)
deleteButton.Attributes.Add ( "onclick", "return
confirm('Delete selected contact?');

Note that it's not in the Page_Load event, so there's no need to parse
through each control. Asp.Net's doing that already when it's creating the
client side webpage, so you may has well hook into that event.

I've not tried the above, so it may need tweaking, any probs let me know.

Thanks.

Daniel.

"vcornjamb" <vc*******@discussions.microsoft.com> wrote in message
news:FE**********************************@microsof t.com...
Hello, I am developing a web form that contains some buttons and a data
grid
which has as its last column link buttons that will delete the data
associated
with that row. Everything works fine, but users have requested a
confirmation
message pop up so the user can confirm the delete. I can not quite get
this to
work. Here are the facts:

I am working in the Microsoft Development Environment 2003 (Version
7.1.3088) and Microsoft .Net Framework 1.1 (Version 1.1.4322).

I have the following controls on the form
Protected WithEvents btnNewTrainingRoom As
System.Web.UI.WebControls.LinkButton
Protected WithEvents dgTrainingRooms As System.Web.UI.WebControls.DataGrid

The data grid has four coulumns: first is hidden column, columns 2 and 3
have
linkbuttons denoted as Select and a fourth column with a linkbutton
denoted as
a delete (per the property builder screen). On the property builder
screen
the
select buttons have button types of linkbutton and a command name of
select.
The delete button has a button type of linkbutton and a command name of
delete.

I found a solution for adding a confirmation request on a web site. It
works
like this (note this is not the button where I want this action, I am only
testing)

btnNewTrainingRoom.Attributes.Add("onclick", "return confirm('Delete
selected contact?');")

The above code was tested on the btnNewTrainingRoom button and it does
everything
I am looking for. Now the problem is getting the .Attributes.Add
associated
with the
delete buttons in my data grid.

Adding this code will allow me to add the "onclick" attribute to all of
the
controls
Dim junk As DataGridItem
Dim junk2 As System.Web.UI.Control
For Each junk In dgTrainingRooms.Items ' Iterate through elements.
junk.Attributes.Add("onclick", "return confirm('Delete selected
contact?');")
Next

The confirmation works great, but for every button in the grid including
the
select buttons (which is not good). I only need to nest the
.Attributes.Add
code in an IF/END IF block. My problem is that I can not figure out a
general
way to determine when I have "delete" linkbutton as opposed to a "select"
linkbutton based on the properties available at that point in time. I
have
spent the last two days researching the data members to figure this out,
but
nothing has worked. Hopefully, it is just something I am overlooking.


Nov 18 '05 #3

When the data grid control is rendered to a client, it is simply an HTML
table with rows and columns... Now in the case that you have a control (as
with your delete button), then the file that the client browser actually
views will contain as many "buttons" as there are rows. Because of this, you
need to add the attribute to every control in every row.

If it's taking a long time, consider using paging, then manipulating the
data source in such a way as to return the data set of the current "page".
For example, if page 5 contains rows 50-59, then have the data set that is
bound to the datagrid simply contain these ten records. This should speed
things up considerably.

Thanks.
"vcornjamb" <vc*******@discussions.microsoft.com> wrote in message
news:5B**********************************@microsof t.com...
Dan, thanks the code example was helpful. I got it to work. However,
when
I run the page in the production environment with a fair number of
records,
the page loads very slowly. I placed the code in the ItemCreated event
method for the data grid. It looks like the code is run for every row
created, thus the attribute.add is done multiple times. Is this correct?

Is there a way to add the attribute to the underlying delete linkbutton
so
it is only done once? I can't figure out how to access the underlying
linkbutton and not each of the individual instances. Tried to see want
was
available during the datagrid's load and init events, but could not figure
out a workable solution.

Thanks for your help.

"Dan Bass" wrote:

All you need to do is reference each cell control by column with
something
like this in the ItemCreated event

' Cells[0] points to the first column, Cells[1] would
point
to the second...
' therefore make sure this indexes your relevant delete
button column

LinkButton deleteButton =
DirectCast(e.Item.Cells[0].Controls[0], LinkButton)
deleteButton.Attributes.Add ( "onclick", "return
confirm('Delete selected contact?');

Note that it's not in the Page_Load event, so there's no need to parse
through each control. Asp.Net's doing that already when it's creating the
client side webpage, so you may has well hook into that event.

I've not tried the above, so it may need tweaking, any probs let me know.

Thanks.

Daniel.

"vcornjamb" <vc*******@discussions.microsoft.com> wrote in message
news:FE**********************************@microsof t.com...
> Hello, I am developing a web form that contains some buttons and a
> data
> grid
> which has as its last column link buttons that will delete the data
> associated
> with that row. Everything works fine, but users have requested a
> confirmation
> message pop up so the user can confirm the delete. I can not quite get
> this to
> work. Here are the facts:
>
> I am working in the Microsoft Development Environment 2003 (Version
> 7.1.3088) and Microsoft .Net Framework 1.1 (Version 1.1.4322).
>
> I have the following controls on the form
> Protected WithEvents btnNewTrainingRoom As
> System.Web.UI.WebControls.LinkButton
> Protected WithEvents dgTrainingRooms As
> System.Web.UI.WebControls.DataGrid
>
> The data grid has four coulumns: first is hidden column, columns 2 and
> 3
> have
> linkbuttons denoted as Select and a fourth column with a linkbutton
> denoted as
> a delete (per the property builder screen). On the property builder
> screen
> the
> select buttons have button types of linkbutton and a command name of
> select.
> The delete button has a button type of linkbutton and a command name of
> delete.
>
> I found a solution for adding a confirmation request on a web site.
> It
> works
> like this (note this is not the button where I want this action, I am
> only
> testing)
>
> btnNewTrainingRoom.Attributes.Add("onclick", "return confirm('Delete
> selected contact?');")
>
> The above code was tested on the btnNewTrainingRoom button and it does
> everything
> I am looking for. Now the problem is getting the .Attributes.Add
> associated
> with the
> delete buttons in my data grid.
>
> Adding this code will allow me to add the "onclick" attribute to all of
> the
> controls
> Dim junk As DataGridItem
> Dim junk2 As System.Web.UI.Control
> For Each junk In dgTrainingRooms.Items ' Iterate through elements.
> junk.Attributes.Add("onclick", "return confirm('Delete selected
> contact?');")
> Next
>
> The confirmation works great, but for every button in the grid
> including
> the
> select buttons (which is not good). I only need to nest the
> .Attributes.Add
> code in an IF/END IF block. My problem is that I can not figure out a
> general
> way to determine when I have "delete" linkbutton as opposed to a
> "select"
> linkbutton based on the properties available at that point in time. I
> have
> spent the last two days researching the data members to figure this
> out,
> but
> nothing has worked. Hopefully, it is just something I am overlooking.


Nov 18 '05 #4

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

0
by: Griff | last post by:
Hi, I have a button column placed on a datagrid at design time that is captioned "Delete". When the user clicks the button, I want to display a confirmation message, that they want to delete...
0
by: Ron Clarke | last post by:
I have a small web app that displays data from a SQL Server database. Using a DataGrid control on a page, the user can delete a row from the database. This works fine. But I want to prompt the user...
6
by: Dave | last post by:
Hello. I want to prompt user for some action with Yes/No message, I know some tricks in JavaScript, but I need to handle the user answer at server side. Exactly I want to prompt user for...
6
by: JenHu | last post by:
Hi experts, I want to add a delete button in my datagrid, and before it deletes from database, I want to have a confirm dialog box for this deletion. I am entry level to the vb.net, and don't...
4
by: DrData | last post by:
I'm working on an ASP.Net application written in C#. On one page, there are several datagrid controls used to display, edit and delete detail records relating to the master record also displayed on...
5
by: Samy | last post by:
Hi There, I have a label in a datagrid which I make it a input type = radio in ItemDataBound so that radio buttons are shown in the datagrid. This is how I have it... ASPX... <asp:Label...
5
by: Jeff User | last post by:
Hello ..NET 1.1, VS 2003, C# & asp.net I have tried to follow msdn instructions and samples but I can not get an event to fire for this button on the datagrid. There has to be something obvious...
2
by: simon_eyer | last post by:
Hi, I use a datagrid with a delete command. I create a validation on the delete command and i have a problem: the confirmation message is supposes to appear each time I do this command but it...
1
vivek kushwaha
by: vivek kushwaha | last post by:
Hi, i have codes like this. code behind page Private Sub DataGrid1_ItemCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridCommandEventArgs) Handles...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
0
by: Faith0G | last post by:
I am starting a new it consulting business and it's been a while since I setup a new website. Is wordpress still the best web based software for hosting a 5 page website? The webpages will be...
0
by: ryjfgjl | last post by:
In our work, we often need to import Excel data into databases (such as MySQL, SQL Server, Oracle) for data analysis and processing. Usually, we use database tools like Navicat or the Excel import...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.