JavaScript API
Datastar is intentional about not (indecently) exposing itself in the global scope – you should be able to do everything you need via Datastar expressions in attribute plugins and datastar-execute-script
SSE events.
When troubleshooting an issue, it may be useful to see the current state of the signals. The easiest way to do this is by outputting them in JSON format using data-text
.
<div data-text="ctx.signals.JSON()"></div>
For edge-cases in which you find yourself having to change the DOM without involving Datastar, you can import Datastar and apply it to any element and its children.
<script type="module">
import { Datastar } from '/path/to/datastar.js'
Datastar.apply(document.body)
</script>
Public Methods#
The Datastar object exposes the following methods.
apply()
#
Applies all plugins to the provided element and its children.
Datastar.apply(document.body)
load()
#
Loads all plugins and applies them to the DOM.
Datastar.load()
Public Properties#
The Datastar object exposes the following properties.
signals
#
The signal root, on which you can access signal methods. Beware that you should avoid using this for anything other than troubleshooting.
Datastar.signals.values()
version
#
The current version number.
Datastar.version