How do I use Ajax to display progress through steps..

Posted on 2010-09-13
Last Modified: 2012-08-14
I am using ASP.Net with and I have read how to use the update progress control panel to display something while the page processes.

I want to take theis a step further and without going into the detail of exactly what the page is doing, if somebody could demo the following basics for me, that would be great..

I am trying to get my head around presenting the user with detailed progress as the server processes a number of steps (interacting with a database with some transactions that could take a long time).

Between some steps, I need the user to have the option to cancel.

Now, traditionally, there would be a lot of complete page post backs but I understand that Ajax can make this much simpler and look neater without posting the whole page back all the time.

The exercise below would probably do a lot for me in terms of understand the power of Ajax and ithe principals would be very useful to me in a lot of places.

Could somebody please tell me the aspx code and the VB (sorry, VB is the preferred language) for the following steps:

1. the page opens and a button is presented that says "go".
2. When the user presses go, an update panel says.."Doing step 1." This message is displayed as soon as the user presses go.
3. After 10 seconds (system.threading.wait is OK for now), the user is presented with the previous text plus on the next line.. "Completed step 1, doing step 2..."
4. After 10 seconds, the progress text is appended with "Completed step 2... do you want to do step 3?" Two buttons are presented with "Yes" and "no"
5. If the user presses "Yes", the buttons go away and the system waits for another 10 seconds and the progress text is appended with "Completed step 3. Done"
6. If the user presses no, the buttons go away and progress text is appended with "User decided to stop"

Question by:MWilliamsBolton

Expert Comment

ID: 33668759
ultimately, you have to spawn off your long running process and use another mechanism to return periodic updates to the browser.

this article is older - but the principals are still correct -

or here is another version using MVC and jquery

Accepted Solution

DjDezmond earned 500 total points
ID: 33670467
I used this code to execute a routine a number of times depending on how many files it found in a directory. Unfortunately, its in C#, so I will try convert to on the fly:

It works on the principle that you have Ajax installed, and a class named clsBackEnd() with all the relavant code inside it. One instance (per connected client) will be saved as a session variable and referenced when needed.

For the confirmation buttons to appear after step two, just add another div section (with visible field set to false) with the two buttons inside, when step 2 is reached, disable the timer, and make the div visible. set the onclick events to reenable the timer or not depending on which button is pressed.

I hope this is easy to follow...
<asp:Button ID="cmdImport" runat="server" Text="Import" onclick="cmdImport_Click" />

            <div id="Importing" runat="server" visible="false">
                <asp:UpdatePanel ID="ImportingPanel" UpdateMode="Conditional" runat="server">
                           <legend>Importing spreadsheets</legend>
                              Dim BackendControl as clsBackend = DirectCast(Session("objBackEnd"), clsBackEnd)
                              Select case BackendControl.DoNextStep()
                                  Case 2
                                    'Next step is 2
                                    UpdateText.innerText = "something about next step 2"
                                  Case 3
                                    'Next step is 3
                                    UpdateText.innerText = "something about next step 3"
                                  Case 1
                                    'Steps have finished.
                                    AutoPostBack.Enabled = false
                                    Importing.Visible = false
                              End Select
                            <br />
                            <div id="UpdateText" runat="server"></div>
                            <br />
                            <asp:Timer ID="AutoPostBack" Interval="10" Enabled="true" runat="server"></asp:Timer>
                <br />
                <p style="font-weight:bold">
                    Please do not navigate away from this page during this process.


'  Page Load'
        if Session("objBackEnd") = null Then            
            Dim BackEnd as clsBackEnd = new clsBackEnd()
            Session("objBackEnd") = BackEnd
        End If

'  cmdImport_Click
        ImportStatus.Visible = false
        Importing.Visible = true
        'Do Step one (referencing clsBackend if needed):
        Dim BackEnd as clsBackEnd = Session("objBackEnd")
        UpdateText.Text = "Something about step one being complete"

'  clsBackend()
        Private Dim _intStep as Integer = 1

        Function DoNextStep() as Integer
          Select case _intStep
             Case 1
               'Do step 1
             Case 2
               'Do step 2
             Case 3
                'Do final step 3
                _intStep = 1
                Return _intStep 
          End Select
          _intStep = _intStep + 1
          Return _intStep
        End Function

Open in new window


Expert Comment

ID: 33670516
by the way, that works on the assumption that you dont initiate step one from the cmdImport button. Making the "Importing" div visible, initialises the timer to start ticking, which automatically executes step one on the first timer tick. Please ignore where I have said "'Do step one" in the server side code, in fact there you would be placing your text that states step one is about to begin...

Also ensure the div section containing the two buttons, is somewhere in the "UpdatePanel" section.

I would imagine you will need to tinker about with this abit before you can use it, but the general idea and principle is there. But please bear in mind, this will execute your steps sychronously, which means if the database read/write routines you plan to execute are quite juicy, then there will be a delay before the postback completes.

Expert Comment

ID: 33679129
- Here is an example have just made for you, instead of using Update Panel, I advise you to use web service which is better, please rename the WebService_asmx to WebService.asmx because the EE server doesn't allow me to upload file with .asmx in extension.

Author Closing Comment

ID: 33892438
Sorry it has taken so long to respond..

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Question about JQuery and 3 30
ajax jquery 3 25 DataGridView show bit field as Text column not CheckBox column 5 18
Change to file doesn't show up 16 50
jQuery is a JavaScript library that greatly simplifies JavaScript programming. AJAX is an acronym formed from "Asynchronous JavaScript and XML."  AJAX refers to any communication between client and server, when the human client does not observe a…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit If you want to manage em…

789 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