The read-only previousSibling
property of the Node
interface returns the node immediately preceding the specified one in its parent's childNodes
list, or null
if the specified node is the first in that list.
Note: Browsers insert text nodes into a document to represent whitespace in the source markup. Therefore a node obtained, for example, using Node.firstChild
or Node.previousSibling
may refer to a whitespace text node rather than the actual element the author intended to get.
See Whitespace in the DOM for more information.
You can use previousElementSibling
to get the previous element node (skipping text nodes and any other non-element nodes).
To navigate the opposite way through the child nodes list use Node.nextSibling.
A Node
representing the previous sibling of the current node, or null
if there are none.
The following examples demonstrate how previousSibling
works with and without text nodes mixed in with elements.
In this example, we have a series of img
elements directly adjacent to each other, with no whitespace between them.
<img id="b0" /><img id="b1" /><img id="b2" />
document.getElementById("b1").previousSibling;
document.getElementById("b2").previousSibling.id;
In this example, there are whitespace text nodes (line breaks) between the img
elements.
<img id="b0" />
<img id="b1" />
<img id="b2" />
document.getElementById("b1").previousSibling;
document.getElementById("b1").previousSibling.previousSibling;
document.getElementById("b2").previousSibling.previousSibling;
document.getElementById("b2").previousSibling;
document.getElementById("b2").previousSibling.id;