diff --git a/www/content/QUIRKS.md b/www/content/QUIRKS.md index b485a7669..33c00281e 100644 --- a/www/content/QUIRKS.md +++ b/www/content/QUIRKS.md @@ -115,7 +115,7 @@ If you want to specifically allow `422` responses to swap, you can use this conf Here is a meta tag allowing all responses to swap: ```html - + ``` ## `GET` Requests on Non-Form Elements Do Not Include Form Values by Default diff --git a/www/content/docs.md b/www/content/docs.md index 65dbffcdf..d891e82b1 100644 --- a/www/content/docs.md +++ b/www/content/docs.md @@ -1415,6 +1415,9 @@ be possible using a standard `on*` property, but it can be done using the `hx-on Here the `example` parameter is added to the `POST` request before it is issued, with the value 'Hello Scripting!'. +Another usecase is to [reset user input](@/examples/reset-user-input.md) on successful requests using the `afterRequest` +event, avoiding the need for something like an out of band swap. + The `hx-on*` attributes are a very simple mechanism for generalized embedded scripting. It is _not_ a replacement for more fully developed front-end scripting solutions such as AlpineJS or hyperscript. It can, however, augment a VanillaJS-based approach to scripting in your htmx-powered application. diff --git a/www/content/events.md b/www/content/events.md index 568ec94e4..39a054b61 100644 --- a/www/content/events.md +++ b/www/content/events.md @@ -126,10 +126,12 @@ This event is triggered right before a request is sent. You may not cancel the ### Event - `htmx:beforeSwap` {#htmx:beforeSwap} -This event is triggered before any new content has been [swapped into the DOM](@/docs.md#swapping). If you call `preventDefault()` on the event to cancel it, no swap will occur. +This event is triggered before any new content has been [swapped into the DOM](@/docs.md#swapping). +Most values on `detail` can be set to override subsequent behavior, other than where response headers take precedence. +If you call `preventDefault()` on the event to cancel it, no swap will occur. -You can modify the default swap behavior by modifying the `shouldSwap` and `target` properties of the event detail. See -the documentation on [configuring swapping](@/docs.md#modifying_swapping_behavior_with_events) for more details. +You can modify the default swap behavior by modifying the `shouldSwap`, `selectOverride`, `swapOverride` and `target` properties of the event detail. +See the documentation on [configuring swapping](@/docs.md#modifying_swapping_behavior_with_events) for more details. ##### Details @@ -139,6 +141,10 @@ the documentation on [configuring swapping](@/docs.md#modifying_swapping_behavio * `detail.requestConfig.elt` - the element that dispatched the request * `detail.shouldSwap` - if the content will be swapped (defaults to `false` for non-200 response codes) * `detail.ignoreTitle` - if `true` any title tag in the response will be ignored +* `detail.isError` - whether error events should be triggered and also determines the values of `detail.successful` and `detail.failed` in later events +* `detail.serverResponse` - the server response as text to be used for the swap +* `detail.selectOverride` - add this to use instead of an [`hx-select`](@/attributes/hx-select.md) value +* `detail.swapOverride` - add this to use instead of an [`hx-swap`](@/attributes/hx-swap.md) value * `detail.target` - the target of the swap ### Event - `htmx:beforeTransition` {#htmx:beforeTransition} diff --git a/www/content/examples/_index.md b/www/content/examples/_index.md index 2ab4b4d77..bc98a29bd 100644 --- a/www/content/examples/_index.md +++ b/www/content/examples/_index.md @@ -30,6 +30,7 @@ You can copy and paste them and then adjust them for your needs. | [Animations](@/examples/animations.md) | Demonstrates various animation techniques | | [File Upload](@/examples/file-upload.md) | Demonstrates how to upload a file via ajax with a progress bar | | [Preserving File Inputs after Form Errors](@/examples/file-upload-input.md) | Demonstrates how to preserve file inputs after form errors | +| [Reset User Input](@/examples/reset-user-input.md) | Demonstrates how to reset form inputs after submission | | [Dialogs - Browser](@/examples/dialogs.md) | Demonstrates the prompt and confirm dialogs | | [Dialogs - UIKit](@/examples/modal-uikit.md) | Demonstrates modal dialogs using UIKit | | [Dialogs - Bootstrap](@/examples/modal-bootstrap.md) | Demonstrates modal dialogs using Bootstrap | diff --git a/www/content/examples/bulk-update.md b/www/content/examples/bulk-update.md index c164f4151..5a503e828 100644 --- a/www/content/examples/bulk-update.md +++ b/www/content/examples/bulk-update.md @@ -10,7 +10,7 @@ values in the form submission (`POST` request): ```html