Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Javascript and Ajax Updatepanel Postbacks

Posted on 2010-11-27
9
Medium Priority
?
498 Views
Last Modified: 2012-05-10
Hello experts!

Here is the code that is causing me trouble.

function check() {
                  document.getElementById("InputBoxTypeText").focus();
        }

        Sys.WebForms.PageRequestManager.getInstance().add_endRequest(check);

Open in new window


My understanding of this is that after a postback, it should set the focus to the text input, however this does not appear to work.  In order to debug, I added an alert() to the javascript:

function check() {
                  alert("test");
                  document.getElementById("InputBoxTypeText").focus();
        }

        Sys.WebForms.PageRequestManager.getInstance().add_endRequest(check);

Open in new window


When I run this, the alert comes up and then the focus is set correctly.

Any ideas?  I'm sure i'm missing something fairly obvious...

Thanks,

DT
0
Comment
Question by:DreadedTuesday
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 4
9 Comments
 
LVL 18

Expert Comment

by:Sudaraka Wijesinghe
ID: 34221608
Call to the check() function probably comes before the InputBoxTypeText element is rendered properly. That explain why it works when add the alert, that delays the call to focus.
Try using the pageLoaded event instead of the endRequest.
0
 
LVL 1

Author Comment

by:DreadedTuesday
ID: 34221614
sudaraka,

Thanks for the suggestion; unfortunately I get the same symptoms.

DT
0
 
LVL 18

Accepted Solution

by:
Sudaraka Wijesinghe earned 2000 total points
ID: 34221632
Is the element InputBoxTypeText on the page and enable when the focus is called? Do you see any JavaScript errors?

Try some thing like below. experiment with the delay to see if delaying the call make it works.
function check() {
                  window.setTimeout(document.getElementById("InputBoxTypeText").focus(), 2000);
        }

        Sys.WebForms.PageRequestManager.getInstance().add_endRequest(check);

Open in new window

0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 1

Author Comment

by:DreadedTuesday
ID: 34221648
Wow, that seems to do it!  Nicely diagnosed, I had not even considered that.  Looks like my skills are rustier than i thought...
0
 
LVL 18

Expert Comment

by:Sudaraka Wijesinghe
ID: 34221679
Glad to hear it worked. But I wouldn't use a delay as a final solution for this as it would still fail in a situation like in a slow internet connection.
You will need to find out an event that make the element focusable and call the check function from there, or make sure the element is focusable when the  pageLoaded or on endRequest events occur.
0
 
LVL 1

Author Comment

by:DreadedTuesday
ID: 34221728
Do you have any suggestions?  The text input in question needs to be in focus to accept input from a handheld barcode scanner (it enters data into whatever is in focus at the time).  I have it getting the first one, but when it updates and returns the page it needs to reset the focus so the user doesnt have to manually select the box again.
0
 
LVL 18

Expert Comment

by:Sudaraka Wijesinghe
ID: 34221899
Does the page reload after submitting the first one? if so, you can call this code on window.onload or dom ready event.
0
 
LVL 1

Author Comment

by:DreadedTuesday
ID: 34221923
the whole page doesnt reload, just the updatepanel.  I have it doign this at the moment:

            var elem = document.getElementById("InputBoxTypeText");
            elem.focus();
            while (elem != document.activeElement) {
                elem = document.getElementById("InputBoxTypeText");
                elem.focus();
            }

Open in new window

0
 
LVL 18

Expert Comment

by:Sudaraka Wijesinghe
ID: 34221926
Nice workaround!
Thanks for the points.
0

Featured Post

The top UI technologies you need to be aware of

An important part of the job as a front-end developer is to stay up to date and in contact with new tools, trends and workflows. That’s why you cannot miss this upcoming webinar to explore the latest trends in UI technologies!

Question has a verified solution.

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

I've been trying to accomplish this for a while and it just struck me yesterday how to accomplish this task. I have done searches all over the internet looking for ways to email pages from my applications and finally I have done it!!! Every single s…
Introduction HTML checkboxes provide the perfect way for a web developer to receive client input when the client's options might be none, one or many.  But the PHP code for processing the checkboxes can be confusing at first.  What if a checkbox is…
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

721 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