Solved

How to implement synchronous pause with JScript?

Posted on 2011-02-13
11
757 Views
Last Modified: 2012-05-11
I want to implement synchronous pause with JScript. Unfortunately there is no delay or pause or wait function in JScript library to support this functionality as JScript is single threaded. Is there any other way to implement this? Use of setinterval or settimeout functions have been ruled out because they provide asynchronous wait not sychronous. Other option i.e. writing pause/sleep/wait function using Date object is also ruled out because it keeps the browser busy in doing some activity instead of relinquishing control for some other event to complete and then return control back to same previous method from where this wait/sleep/pause was called. Any help please?
0
Comment
Question by:sachitjain
  • 6
  • 5
11 Comments
 
LVL 40

Expert Comment

by:gurvinder372
ID: 34885742
looks like this code i had was just waiting for you

function pausecomp (millis)
{
      var date = new Date();
      var curDate = null;
      
      do { curDate = new Date(); }
      while(curDate-date < millis);
}
0
 
LVL 12

Author Comment

by:sachitjain
ID: 34885763
Thanks Gurvinder but I have already it with reason out and mentioned in my query also. :-)
0
 
LVL 12

Author Comment

by:sachitjain
ID: 34885766
Thanks Gurvinder but I have already ruled it out with reason and mentioned in my query also. :-)
0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 34885779
what kind of wait are you looking for, btw, if you want the browser to allow you to do something without the wait being asynchronous?
0
 
LVL 12

Author Comment

by:sachitjain
ID: 34885813
Actually its linked with my other open query http://www.experts-exchange.com/Programming/Languages/Scripting/JScript/Q_26725224.html only.

For some reason my synchronous XMLHttp calls error out with 12031 status 1 out of 10 times so I thought of making them asynchronous and tracking the call output with OnReadyChangeState event. Now the challenge I am facing is with keeping the calling function in wait state until corresponding OnReadyChangeState event returns relevant output.
0
Top 6 Sources for Identifying Threat Actor TTPs

Understanding your enemy is essential. These six sources will help you identify the most popular threat actor tactics, techniques, and procedures (TTPs).

 
LVL 40

Expert Comment

by:gurvinder372
ID: 34885865
you can add the overlaid loading (or please wait) image on the screen, so that user cannot take any action.

http://visionmasterdesigns.com/tutorial-adding-a-ajax-spinner-in-the-center-of-web-page-using-prototype/
http://itprism.com/blog/ajax-loading-overlay
0
 
LVL 12

Author Comment

by:sachitjain
ID: 34885969
Gurvinder

Actually these synchronous calls are being made from mid of some request processing so there is no scope of holding the user to perform the next activity. Basically a synchronous XMLHTTP call is being made and based on its output some other processing is happening to suffice the desired request.

Had I got some way to implement synchronous wait in a calling method and relinquish the execution control to OnReadyChangeState event for that particular waiting period, I would have achieved my objective.
0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 34886073
<<Actually these synchronous calls are being made from mid of some request processing>>
please elaborate on this
0
 
LVL 12

Author Comment

by:sachitjain
ID: 34886114
Actually scenario is like this
function doSomething(){
      //some statements of code
      var xmloutput = SyncXMLHTTPCall(URL, XMLInput);
      //some more manipulation over xmloutput received in previous state
}

And this function doSomething also could be called in of the other existing JS functions so there is no scope of shifting following statements into some callback JS function.
0
 
LVL 40

Accepted Solution

by:
gurvinder372 earned 500 total points
ID: 34914347
why don't you turn it into this?
function doSomething(){
      //some statements of code
      var xmloutput = SyncXMLHTTPCall(URL, XMLInput);
      //some more manipulation over xmloutput received in previous state
}


turn it into

function doSomething(){
      //some statements of code
      var xmloutput = SyncXMLHTTPCall(URL, XMLInput);
      setTimeout("nextFunction()", 5000); // a delay of 5 seconds before next function is called
}

function nextFunction()
{
   //some more manipulation over xmloutput received in previous state
}

0
 
LVL 12

Author Closing Comment

by:sachitjain
ID: 35340752
Thanks
0

Featured Post

Highfive + Dolby Voice = No More Audio Complaints!

Poor audio quality is one of the top reasons people don’t use video conferencing. Get the crispest, clearest audio powered by Dolby Voice in every meeting. Highfive and Dolby Voice deliver the best video conferencing and audio experience for every meeting and every room.

Join & Write a Comment

Are you unable to connect or configure Hotmail email account in Microsoft Outlook 2010, 2007? Or Outlook.com emails are not downloading to Outlook? Lets’ see the problem and resolve Outlook Connector error syncing folder hierarchy (0x8004102A).
For cloud, the “train has left the station” and in the Microsoft ERP & CRM world, that means the next generation of enterprise software from Microsoft is here: Dynamics 365 is Microsoft’s new integrated business solution that unifies CRM and ERP fun…
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…
When you create an app prototype with Adobe XD, you can insert system screens -- sharing or Control Center, for example -- with just a few clicks. This video shows you how. You can take the full course on Experts Exchange at http://bit.ly/XDcourse.

758 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

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now