Selector.prevSibling Method

Selects preceding sibling elements.

Syntax

prevSibling

Selector().prevSibling() → Selector

Finds the preceding sibling elements of all nodes in the matched set.

prevSibling(index)

Selector().prevSibling(index) → Selector

Finds the preceding sibling elements of all nodes in the matched set and filters them by index.

Argument Type Description
index Number The zero-based index (0 is the closest node). If index is negative, the index is counted from the end of the matched set.

prevSibling(cssSelector)

Selector().prevSibling(cssSelector) → Selector

Finds the preceding sibling elements of all nodes in the matched set and uses a CSS selector to filter them.

Argument Type Description
cssSelector String The CSS selector string used to filter child elements.

prevSibling(filterFn, dependencies)

Selector().prevSibling(filterFn [, dependencies]) → Selector

Finds the preceding sibling elements of all nodes in the matched set and uses a predicate to filter them.

Argument Type Description
filterFn Function The predicate used to filter the elements.
dependencies (optional) Object Functions, variables, or objects passed to the filterFn function.

See Filtering DOM Elements by Predicates.

Examples

// Selects all preceding siblings of all p elements.
Selector('p').prevSibling();

// Selects all closest preceding siblings of all figure elements.
Selector('figure').prevSibling(0);

// Selects all furthest preceding siblings of all option elements.
Selector('option').prevSibling(-1);

// Selects all p elements that are preceding siblings of a blockquote element.
Selector('blockquote').prevSibling('p');

Filtering DOM Elements by Predicates

Functions that search for elements in the DOM tree allow you to use a filterFn predicate to filter the matched set.

The filterFn predicate is executed on the client side and accepts the following parameters:

Parameter Description
node The current matching node.
idx A matching node's zero-based index.
originNode A node from the left-hand selector's matched set whose parents/siblings/children are being iterated.
Selector('section').prevSibling((node, idx, originNode) => {
    // node === the <section>'s preceding sibling node
    // idx === index of the current <section>'s preceding sibling node
    // originNode === the <section> element
});

The dependencies parameter allows you to pass objects to the filterFn client-side scope where they appear as variables.

const isNodeOk = (node, idx, originNode) => { /*...*/ };

Selector('ul').prevSibling((node, idx, originNode) => {
    return isNodeOk(node, idx, originNode);
}, { isNodeOk });