Class Elements
- All Implemented Interfaces:
Serializable, Cloneable, Iterable<Element>, Collection<Element>, List<Element>, RandomAccess, SequencedCollection<Element>
Elements, with methods that act on every element in the list.
To get an Elements object, use the Element.select(String) method.
- See Also:
-
Field Summary
Fields inherited from class AbstractList
modCount -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionAdd the class name to every matched element'sclassattribute.Insert the supplied HTML after each matched element's outer HTML.Add the supplied HTML to the end of each matched element's inner HTML.Get an attribute value from the first matched element that has the attribute.Set an attribute on all matched elements.Insert the supplied HTML before each matched element's outer HTML.childNodesOfType(Class<T> tClass) clone()Creates a deep copy of these elements.comments()GetCommentnodes that are direct child nodes of the selected elements.GetDataNodenodes that are direct child nodes of the selected elements.Get the attribute value for each of the matched elements.eachText()Get the text content of each of the matched elements.empty()Empty (remove all child nodes from) each matched element.eq(int index) Get the nth matched element as an Elements object.filter(NodeFilter nodeFilter) Perform a depth-first filtering on each of the selected elements.first()Get the first matched element.forms()Get theFormElementforms from the selected elements, if any.booleanChecks if any of the matched elements have this attribute defined.booleanDetermine if any of the matched elements have this class name set in theirclassattribute.booleanhasText()Test if any matched Element has any text content, that is not just whitespace.html()Get the combined inner HTML of all matched elements.Set the inner HTML of each matched element.booleanTest if any of the matched elements match the supplied query.last()Get the last matched element.next()Get the immediate next element sibling of each element in this list.Get the immediate next element sibling of each element in this list, filtered by the query.nextAll()Get each of the following element siblings of each element in this list.Get each of the following element siblings of each element in this list, that match the query.Remove elements from this list that match theSelectorquery.Get the combined outer HTML of all matched elements.parents()Get all of the parents and ancestor elements of the matched elements.Add the supplied HTML to the start of each matched element's inner HTML.prev()Get the immediate previous element sibling of each element in this list.Get the immediate previous element sibling of each element in this list, filtered by the query.prevAll()Get each of the previous element siblings of each element in this list.Get each of the previous element siblings of each element in this list, that match the query.remove()Remove each matched element from the DOM.removeAttr(String attributeKey) Remove an attribute from every matched element.removeClass(String className) Remove the class name from every matched element'sclassattribute, if present.Find matching elements within this element list.private ElementsUpdate (rename) the tag name of each matched element.text()Get the combined text of all the matched elements.GetTextNodenodes that are direct child nodes of the selected elements.toggleClass(String className) Toggle the class name on every matched element'sclassattribute.toString()Get the combined outer HTML of all matched elements.traverse(NodeVisitor nodeVisitor) Perform a depth-first traversal on each of the selected elements.unwrap()Removes the matched elements from the DOM, and moves their children up into their parents.val()Get the form element's value of the first matched element.Set the form element's value in each of the matched elements.Wrap the supplied HTML around each matched elements.Methods inherited from class ArrayList
add, add, addAll, addAll, addFirst, addLast, clear, contains, ensureCapacity, equals, forEach, get, getFirst, getLast, hashCode, indexOf, isEmpty, iterator, lastIndexOf, listIterator, listIterator, remove, remove, removeAll, removeFirst, removeIf, removeLast, removeRange, replaceAll, retainAll, set, size, sort, spliterator, subList, toArray, toArray, trimToSizeMethods inherited from class AbstractCollection
containsAllMethods inherited from interface Collection
parallelStream, stream, toArrayMethods inherited from interface List
containsAll, reversed
-
Constructor Details
-
Elements
public Elements() -
Elements
public Elements(int initialCapacity) -
Elements
-
Elements
-
Elements
-
-
Method Details
-
clone
-
attr
Get an attribute value from the first matched element that has the attribute.- Parameters:
attributeKey- The attribute key.- Returns:
- The attribute value from the first matched element that has the attribute.. If no elements were matched (isEmpty() == true), or if the no elements have the attribute, returns empty string.
- See Also:
-
hasAttr
Checks if any of the matched elements have this attribute defined.- Parameters:
attributeKey- attribute key- Returns:
- true if any of the elements have the attribute; false if none do.
-
eachAttr
Get the attribute value for each of the matched elements. If an element does not have this attribute, no value is included in the result set for that element.- Parameters:
attributeKey- the attribute name to return values for. You can add theabs:prefix to the key to get absolute URLs from relative URLs, e.g.:doc.select("a").eachAttr("abs:href").- Returns:
- a list of each element's attribute value for the attribute
-
attr
-
removeAttr
-
addClass
-
removeClass
-
toggleClass
-
hasClass
Determine if any of the matched elements have this class name set in theirclassattribute.- Parameters:
className- class name to check for- Returns:
- true if any do, false if none do
-
val
Get the form element's value of the first matched element.- Returns:
- The form element's value, or empty if not set.
- See Also:
-
val
-
text
Get the combined text of all the matched elements.Note that it is possible to get repeats if the matched elements contain both parent elements and their own children, as the Element.text() method returns the combined text of a parent and all its children.
- Returns:
- string of all text: unescaped and no HTML.
- See Also:
-
hasText
public boolean hasText()Test if any matched Element has any text content, that is not just whitespace.- Returns:
- true if any element has non-blank text content.
- See Also:
-
eachText
-
html
Get the combined inner HTML of all matched elements.- Returns:
- string of all element's inner HTML.
- See Also:
-
outerHtml
Get the combined outer HTML of all matched elements.- Returns:
- string of all element's outer HTML.
- See Also:
-
toString
Get the combined outer HTML of all matched elements. Alias ofouterHtml().- Overrides:
toStringin classAbstractCollection<Element>- Returns:
- string of all element's outer HTML.
- See Also:
-
tagName
-
html
-
prepend
-
append
-
before
-
after
-
wrap
Wrap the supplied HTML around each matched elements. For example, with HTML<p><b>This</b> is <b>Jsoup</b></p>,doc.select("b").wrap("<i></i>");becomes<p><i><b>This</b></i> is <i><b>jsoup</b></i></p>- Parameters:
html- HTML to wrap around each element, e.g.<div class="head"></div>. Can be arbitrarily deep.- Returns:
- this (for chaining)
- See Also:
-
unwrap
Removes the matched elements from the DOM, and moves their children up into their parents. This has the effect of dropping the elements but keeping their children.This is useful for e.g removing unwanted formatting elements but keeping their contents. E.g. with HTML:
<div><font>One</font> <font><a href="/">Two</a></font></div>doc.select("font").unwrap();HTML =
<div>One <a href="/">Two</a></div>- Returns:
- this (for chaining)
- See Also:
-
empty
Empty (remove all child nodes from) each matched element. This is similar to setting the inner HTML of each element to nothing.E.g. HTML:
<div><p>Hello <b>there</b></p> <p>now</p></div>
doc.select("p").empty();
HTML =<div><p></p> <p></p></div>- Returns:
- this, for chaining
- See Also:
-
remove
Remove each matched element from the DOM. This is similar to setting the outer HTML of each element to nothing.E.g. HTML:
<div><p>Hello</p> <p>there</p> <img /></div>
doc.select("p").remove();
HTML =<div> <img /></div>Note that this method should not be used to clean user-submitted HTML; rather, use
Cleanerto clean HTML.- Returns:
- this, for chaining
- See Also:
-
select
-
not
Remove elements from this list that match theSelectorquery.E.g. HTML:
<div class=logo>One</div> <div>Two</div>
Elements divs = doc.select("div").not(".logo");
Result:divs: [<div>Two</div>]- Parameters:
query- the selector query whose results should be removed from these elements- Returns:
- a new elements list that contains only the filtered results
-
eq
Get the nth matched element as an Elements object.See also
ArrayList.get(int)to retrieve an Element.- Parameters:
index- the (zero-based) index of the element in the list to retain- Returns:
- Elements containing only the specified element, or, if that element did not exist, an empty list.
-
is
Test if any of the matched elements match the supplied query.- Parameters:
query- A selector- Returns:
- true if at least one element in the list matches the query.
-
next
Get the immediate next element sibling of each element in this list.- Returns:
- next element siblings.
-
next
-
nextAll
Get each of the following element siblings of each element in this list.- Returns:
- all following element siblings.
-
nextAll
-
prev
Get the immediate previous element sibling of each element in this list.- Returns:
- previous element siblings.
-
prev
-
prevAll
Get each of the previous element siblings of each element in this list.- Returns:
- all previous element siblings.
-
prevAll
-
siblings
-
parents
Get all of the parents and ancestor elements of the matched elements.- Returns:
- all of the parents and ancestor elements of the matched elements
-
first
Get the first matched element.- Returns:
- The first matched element, or
nullif contents is empty.
-
last
Get the last matched element.- Returns:
- The last matched element, or
nullif contents is empty.
-
traverse
Perform a depth-first traversal on each of the selected elements.- Parameters:
nodeVisitor- the visitor callbacks to perform on each node- Returns:
- this, for chaining
-
filter
Perform a depth-first filtering on each of the selected elements.- Parameters:
nodeFilter- the filter callbacks to perform on each node- Returns:
- this, for chaining
-
forms
Get theFormElementforms from the selected elements, if any.- Returns:
- a list of
FormElements pulled from the matched elements. The list will be empty if the elements contain no forms.
-
comments
-
textNodes
-
dataNodes
-
childNodesOfType
-