Exquery

A simple Elixir DOM library for building a tree from an HTML string and then selecting elements that lurk within.

Example

Selecting an li :tag with specific attrs using one/2

"""
<div class="red-fish">
  <ul class="blue-fish">
    <li class="one-fish">Hello</li>
    <li class="two-fish">World</li>
  </ul>
</div>
"""
|> Exquery.tree
|> Exquery.Query.one({:tag, "li", [{"class", "one-fish"}]})

This evaluates to:

{{:tag, "li", [{"class", "one-fish"}]}, [{:text, "Hello", []}]}

Similarly, you can select all elements using all/2

"""
<div class="red-fish">
  <ul class="blue-fish">
    <li class="one-fish">Hello</li>
    <li class="two-fish">World</li>
  </ul>
</div>
"""
|> Exquery.tree
|> Exquery.Query.all({:tag, "li", []})

This evaluates to:

[{{:tag, "li", [{"class", "one-fish"}]}, [{:text, "Hello", []}]},
 {{:tag, "li", [{"class", "two-fish"}]}, [{:text, "World", []}]}]

You can select a sibling using before/3 andnext/3`

"""
<div class="red-fish">
  <ul class="blue-fish">
    <li class="one-fish">Hello</li>
    <li class="two-fish">World</li>
  </ul>
</div>
"""
|> Exquery.tree
|> Exquery.Query.next({:tag, "li", []})

This evaluates to:

{{:tag, "li", [{"class", "two-fish"}]}, [{:text, "World", []}]}
"""
<div class="red-fish">
  <ul class="blue-fish">
    <li class="one-fish">Hello</li>
    <li class="two-fish">World</li>
  </ul>
</div>
"""
|> Exquery.tree
|> Exquery.Query.before({:tag, "li", [{"class", "two-fish"}]})

This evaluates to:

{{:tag, "li", [{"class", "one-fish"}]}, [{:text, "Hello", []}]}

Todo: