开发者

Does changing window.location stop execution of javascript?

开发者 https://www.devze.com 2022-12-24 06:07 出处:网络
When writing server-side code you need to explicitly stop execution after sending a \"Location: ...\" header to the client or your code will continue to execute in the background.

When writing server-side code you need to explicitly stop execution after sending a "Location: ..." header to the client or your code will continue to execute in the background.

But what about when you change window.location in a client-side script? Does this immediatel开发者_如何学编程y stop execution of the current script or is it up to the programmer to make sure that any code located after this call is not reached?


Does this immediately stop execution of the current script

No, the remaining handler script will execute to the end before control returns to the browser and events start happening. When loading of the new page gets far enough for ‘navigation’ to occur, the beforeunload and unload events will fire, then the page and any script in it will become inactive.

However, any further queued events and timeouts might not fire. For example if you navigate the page in a click handler of a form submit button and don't cancel the default action, it is possible (race condition) for the navigation to occur before the submit event queued by the default action of the click.


Setting window.location does not implicitly stop JS execution. Take the following as an example:

function locationTest() {
  window.location = 'http://www.google.com/';
  window.open('http://www.yahoo.com/');
}

locationTest();

Try running that from Firebug/Web Inspector/etc. and you'll notice that the current window will load Google, but a new window will open with Yahoo as well.

0

精彩评论

暂无评论...
验证码 换一张
取 消