Action Plugins
Datastar provides the following actions, that can be used in Datastar expressions.
Backend Plugins#
Allow for the integration of any backend service that supports SSE.
@get()
#
Arguments: @get(url: string, options={})
Sends a GET
request to the backend using fetch
, and merges the response with the current DOM and signals. The URL can be any valid URL and the response must contain zero or more Datastar SSE events.
<button data-on-click="@get('/endpoint')"></button>
By default, all requests are sent with a {datastar: *}
object containing the current signals (except for local signals whose keys begin with an underscore). When using a get
request, the signals are sent as a query parameter, otherwise they are send as a JSON body.
It is possible to send form encoded requests by setting the contentType
option to form
. This sends GET requests using application/x-www-form-urlencoded
encoding and non-GET requests using multipart/form-data
encoding. See the form data example.
Options#
The @get()
action takes a second argument of options.
contentType
- The type of content to send. A value ofjson
sends all signals in a JSON request. A value ofform
tells the action to look for the closest form to the element on which it is placed (unless aselector
option is provided), perform validation on the form elements, and send them to the backend using a form request (no signals are sent). Defaults tojson
.includeLocal
- Whether to include local signals (those beggining with an underscore) in the request. Defaults tofalse
.selector
- Optionally specifies a form to send when thecontentType
option is set toform
. If the value isnull
, the closest form is used. Defaults tonull
.headers
- An object containing headers to send with the request.openWhenHidden
- Whether to keep the connection open with the page is hidden. Useful for dashboards but can cause a drain on battery life and other resources when enabled. Defaults tofalse
retryInterval
- The retry interval in milliseconds. Defaults to1000
(1 second).retryScaler
- A numeric multiplier applied to scale retry wait times. Defaults to2
.retryMaxWaitMs
- The maximum allowable wait time in milliseconds between retries. Defaults to30000
(30 seconds).retryMaxCount
- The maximum number of retry attempts. Defaults to10
.abort
- An AbortSignal object that can be used to cancel the request.
<div data-on-click="@get('/endpoint', {
includeLocal: true,
headers: {
'X-Csrf-Token': 'JImikTbsoCYQ9oGOcvugov0Awc5LbqFsZW6ObRCxuqFHDdPbuFyc4ksPVVa9+EB4Ag+VU6rpc680edNFswIRwg==',
},
openWhenHidden: true,
})"></div>
@post()
#
Arguments: @post(url: string, options={})
Works the same as @get()
but sends a POST
request to the backend.
<button data-on-click="@post('/endpoint')"></button>
@put()
#
Arguments: @put(url: string, options={})
Works the same as @get()
but sends a PUT
request to the backend.
<button data-on-click="@put('/endpoint')"></button>
@patch()
#
Arguments: @patch(url: string, options={})
Works the same as @get()
but sends a PATCH
request to the backend.
<button data-on-click="@patch('/endpoint')"></button>
@delete()
#
Arguments: @delete(url: string, options={})
Works the same as @get()
but sends a DELETE
request to the backend.
<button data-on-click="@delete('/endpoint')"></button>
Browser Plugins#
Provides actions for performing browser operations.
@clipboard()
#
Arguments: @clipboard(expression: string)
Copies the provided evaluated expression to the clipboard.
<div data-on-click="@clipboard('Hello, world!')"></div>
Logic Plugins#
Provides actions for performing logic operations.
@setAll()
#
Arguments: @setAll(pathPrefix: string, value: any)
Sets all the signals that start with the prefix to the expression provided in the second argument. This is useful for setting all the values of a signal namespace at once.
<div data-on-change="@setAll('foo.', true)"></div>
@toggleAll()
#
Arguments: @toggleAll(pathPrefix: string)
Toggles all the signals that start with the prefix. This is useful for toggling all the values of a signal namespace at once.
<div data-on-click="@toggleAll('foo.')"></div>
@fit()
#
Arguments: @fit(v: number, oldMin: number, oldMax: number, newMin: number, newMax: number, shouldClamp=false, shouldRound=false)
Make a value linear interpolate from an original range to new one.