+++ title = "hx-target" description = """\ The hx-target attribute in htmx allows you to target a different element for swapping than the one issuing the AJAX \ request.""" +++ The `hx-target` attribute allows you to target a different element for swapping than the one issuing the AJAX request. The value of this attribute can be: * A CSS query selector of the element to target. * `this` which indicates that the element that the `hx-target` attribute is on is the target. * `closest ` which will find the [closest](https://developer.mozilla.org/docs/Web/API/Element/closest) ancestor element or itself, that matches the given CSS selector (e.g. `closest tr` will target the closest table row to the element). * `find ` which will find the first child descendant element that matches the given CSS selector. * `next` which resolves to [element.nextElementSibling](https://developer.mozilla.org/docs/Web/API/Element/nextElementSibling) * `next ` which will scan the DOM forward for the first element that matches the given CSS selector. (e.g. `next .error` will target the closest following sibling element with `error` class) * `previous` which resolves to [element.previousElementSibling](https://developer.mozilla.org/docs/Web/API/Element/previousElementSibling) * `previous ` which will scan the DOM backwards for the first element that matches the given CSS selector. (e.g. `previous .error` will target the closest previous sibling with `error` class) Here is an example that targets a div: ```html
``` The response from the `/register` url will be appended to the `div` with the id `response-div`. This example uses `hx-target="this"` to make a link that updates itself when clicked: ```html New link ``` ## Notes * `hx-target` is inherited and can be placed on a parent element