ASP.NET Webforms UpdatePanel Show Progress

Home » ASP.NET AJAX » Web Development » ASP.NET Webforms UpdatePanel Show Progress
ASP.NET Web forms Logo

ASP.NET Webforms has the UpdatePanel and UpdateProgress controls, intended originally to simplify AJAX development. However these are not as easy to use as the designers intended, MVC is far easier when writing CRUD pages using AJAX or otherwise.

In a legacy app recently, I came across some code where a FormView was inside an UpdatePanel, and the system was not giving the end user any feedback when for example the Update button was pressed when saving edits. This could lead to the user pressing the button twice, the second press causing an update on top of an update, which led to an error. This is what the code looked like:

The UpdateProgress control can be added as follows:

CSS can also be added to overlay the progress panel over the top of the existing page, which makes it non-missable and also discourages the user from pressing any of the buttons on the page (it still is possible to press them). This CSS allows a small 200×200 image to be displayed. I used www.ajaxload.info to generate a simple animated GIF and the following CSS to white out the entire page when the button was pressed:

This just leaves the problem of the user, if they are really determined, to press the Update button twice. I wanted a fairly generic solution because I intended to use this on a lot of pages (couple of dozen at least), so I went with some JavaScript to disable the button that had just been pressed. This solution is not perfect, as it doesn’t stop the user pressing one of the other buttons on the page, but hey, if they are really determined to mess about they could press update and then turn off the PC! Here is the javascript, it disables the sending button at the start of a request and re-enables it at the end of a request:

I then packaged this all up into a user control so it could be included in multiple pages as follows:

Code behind for the user control:

The way this is used in a page is as follows:

I have tried to keep this post as concise as possible, hopefully it will help somebody.

About Phil

I have been working as a software developer since 1983. This blog could have been called "From Fortran 77, C and Cobol to C# in 20 (not so) easy years", but it doesn't sound quite right somehow. Besides I'm talking about what's happened since 2003, not before!

Leave a Reply

Your email address will not be published.


You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">




Top Posts & Pages

Categories

Recent Posts

Recent Comments

Archives

Blogroll

  • Mike Cohn's Blog
  • Scott Hanselman's Blog
- mike@mountaingoatsoftware.com

Traditionally managed projects begin with a kickoff meeting. Here’s why and how agile projects can d [...]

- mike@mountaingoatsoftware.com

Scrum teams know they need to be potentially releasable at the end of the sprint. But do they know e [...]

- mike@mountaingoatsoftware.com

It’s important for most agile teams to estimate both their product and sprint backlogs. But why? [...]

- mike@mountaingoatsoftware.com

This new video series is the perfect primer for Scrum. It’s great prep for the Certified Scrum Maste [...]

- mike@mountaingoatsoftware.com

An agile product backlog should evolve over time, with product backlog items and user stories rising [...]

- Scott Hanselman

You likely know that open source .NET Core is cross platform and it's super easy to do "He [...]

- Scott Hanselman

I run Windows as my daily driver but I use WSL (Windows Subsystem for Linux) all day long but WSL is [...]

- Scott Hanselman

When building my Ultimate Developer PC I picked this motherboard, and it's lovely. ASUS ROG STR [...]

- Scott Hanselman

I'm sure I'll miss some, so if I do, please sound off in the comments and I'll update [...]

- Scott Hanselman

According to https://github.com/dotnet/sourcelink, SourceLink "enables a great source debugging [...]

Meta