Stefan Majewsky
Stefan Majewsky

Reputation: 5555

Why does "window = window.parent;" create an infinite loop?

I was traversing through a frame hierarchy, and tried the following to find the top frame:

var win = window;
while (win.parent) {
    //perform actions on win
    win = win.parent;
}

By now, I know that the correct looping condition must be:

while (win !== top) {

The existence check on win.parent seemingly creates an infinite loop. Is there any particular reason why it is like this? Why should top have a parent?

Upvotes: 6

Views: 1968

Answers (2)

Simon Edström
Simon Edström

Reputation: 6619

You should also check if window.parent == window​ is false. Otherwise you will end up with an infinite loop. If there is no parent, the parent property will reference to itself (infinite loop).

var win = window;
while (win.parent && win.parent != win) {
    //perform actions on win
    win = win.parent;
}​

http://jsfiddle.net/EZfHf/

I found this on MDN:

If a window does not have a parent, its parent property is a reference to itself.

Upvotes: 7

Madara's Ghost
Madara's Ghost

Reputation: 174997

top's parent is itself.

top == top.parent //true

Upvotes: 2

Related Questions