on input from .quantity set #total.innerText to (the value of #price as Number) * (my value as Number)
24 translations
Loading...
Copy To Clipboardclipboard
Copy text to clipboard with feedback
on click call navigator.clipboard.writeText(#code.innerText) put "Copied!" into me wait 2s put "Copy" into me
24 translations
Loading...
Decrement Countercounters
Decrement a numeric counter element
on click decrement #counter
24 translations
Loading...
Default Valuedata
Set default value if not present
on load default my @data-count to "0"
24 translations
Loading...
Disable Form On Submitforms
Disable submit button while processing
on submit add @disabled to <button/> in me put "Submitting..." into <button/> in me
24 translations
Loading...
Document Readywindow-events
Initialize app when element loads
on load call initializeApp()
24 translations
Loading...
Draggable Behaviorbehavior
Makes element draggable with pointer events. Use: install Draggable(dragHandle: ".titlebar")
behavior Draggable(dragHandle)
init
if no dragHandle set dragHandle to me
end
on pointerdown(clientX, clientY) from dragHandle
halt the event
trigger draggable:start
measure x
set startX to it
measure y
set startY to it
set xoff to clientX - startX
set yoff to clientY - startY
repeat until event pointerup from document
wait for pointermove(clientX, clientY) or
pointerup(clientX, clientY) from document
add { left: ${clientX - xoff}px; top: ${clientY - yoff}px; }
trigger draggable:move
end
trigger draggable:end
end
end
24 translations
Loading...
Dropdown Toggleui-components
Toggle dropdown menu visibility
on click toggle .open on next .dropdown-menu halt
24 translations
Loading...
Event Debounceevents
Debounce input for search
on input debounced at 300ms fetch /api/search?q=${my value} as json then put it into #results
24 translations
Loading...
Event Onceevents
Handle event only once
on click once add .initialized to me call setup()
24 translations
Loading...
Event Throttleevents
Throttle scroll handler
on scroll throttled at 100ms call updateScrollPosition()
24 translations
Loading...
Exclusive Accordionui-components
Accordion where only one panel is open
on click remove .open from .accordion-item add .open to closest .accordion-item
24 translations
Loading...
Fade Out And Removeanimation
Fade element out then remove from DOM
on click transition opacity to 0 over 300ms then remove me
24 translations
Loading...
Fetch Dataasync
Fetch data from an API and display it
on click fetch /api/data then put it into #result
24 translations
Loading...
Fetch JSONasync
Fetch JSON data and use a property
on click fetch /api/user as json then set #name.innerText to it.name
24 translations
Loading...
Fetch With Auth Headerasync
Fetch with custom headers and parse the response as JSON
on click fetch /api/me with headers:{Authorization:`Bearer ${$token}`} as JSON then put it.name into me
24 translations
Loading...
Fetch With Error Handlingasync
Handle API errors by checking response body
on click fetch /api/data as json then if it.error put it.error into #error else put it.data into #result end
24 translations
Loading...
Fetch With Loading Stateasync
Show loading indicator during fetch
on click add .loading to me fetch /api/data then remove .loading from me put it into #result
24 translations
Loading...
Fetch With Methodasync
Submit form data via POST
on submit fetch /api/form with method:"POST" body:form
24 translations
Loading...
Fetch Without Throwingasync
Fetch without throwing on errors; check the result before using it
on click fetch /api/users as JSON do not throw then if it set $users to it end
24 translations
Loading...
First In Collectionnavigation
Focus first input in parent form
on click focus first <input/> in closest <form/>
24 translations
Loading...
Focus Elementfocus
Focus an input element
on click focus #input
24 translations
Loading...
Focus Trapaccessibility
Trap focus within modal
on keydown[key=="Tab"] from .modal if target matches last <button/> in .modal focus first <button/> in .modal halt end
24 translations
Loading...
Get Attribute (Possessive Dot)lokascripthyperfixi-extensions
Call getAttribute using possessive dot notation (HyperFixi extension)
on click put my.getAttribute("data-id") into #output
24 translations
Loading...
Get Input Value (Possessive Dot)lokascripthyperfixi-extensions
Mirror input value using possessive dot notation (HyperFixi extension)
on input put my.value into #preview
24 translations
Loading...
Get Valuedata
Get a value and use it
on click get #input.value then log it
24 translations
Loading...
Go Backnavigation
Navigate back in history
on click go back
24 translations
Loading...
Go To URLnavigation
Navigate to a URL
on click go to url "/page"
24 translations
Loading...
Halt Eventcontrol-flow
Stop event propagation
on click halt the event then toggle .active
24 translations
Loading...
Hide Elementvisibility
Hide an element
on click hide #modal
24 translations
Loading...
Hide With Transitionvisibility
Hide element with opacity transition
on click hide me with *opacity
24 translations
Loading...
If Conditioncontrol-flow
Conditional execution based on state
on click if I match .active then remove .active else add .active end
24 translations
Loading...
If Element Existscontrol-flow
Check if element exists before action
on click if #modal exists show #modal else make a <div#modal/> put it into body end
24 translations
Loading...
If Matches Selectorcontrol-flow
Check if element matches selector
on click if I match .disabled halt else toggle .active end
24 translations
Loading...
If Value Emptycontrol-flow
Validate empty input
on blur if my value is empty add .error to me put "Required" into next .error-message end
Walks up the parent chain to find ^count and writes the nearest defining ancestor
on click increment ^count
24 translations
Loading...
Inline JavaScriptadvanced
Execute inline JavaScript
on click js console.log("from js") end
24 translations
Loading...
Input Mirrorforms
Mirror input value to another element
on input put my value into #preview
24 translations
Loading...
Input Validationforms
Validate input on blur
on blur if my value is empty add .error to me else remove .error from me end
24 translations
Loading...
Install Behaviorbehaviors
Install a reusable behavior on an element. Replace "Draggable" with any defined behavior name (e.g., Sortable, Closeable).
install Draggable
24 translations
Loading...
Intercept: Cache Strategiesbothservice-workers
Service worker DSL with precaching, per-route strategies, and offline fallback
intercept / precache /, /style.css, /app.js as "v1" on /api/* use network-first on *.css, *.js use cache-first on * use stale-while-revalidate offline fallback /offline.html end
24 translations
Loading...
Its Value (Possessive Dot)lokascripthyperfixi-extensions
Access result property using its.property syntax (HyperFixi extension)
on click fetch /api/data then put its.name into #result
24 translations
Loading...
Key Combinationevents
Handle Shift+Enter key combo
on keydown[key=="Enter"] if event.shiftKey call submitAndContinue() end
24 translations
Loading...
Key Filter With `is`events
Filter keyboard events using the modern `is` comparison syntax
on keyup[key is 'Escape'] clear me
24 translations
Loading...
Last In Collectionnavigation
Scroll to last message in chat
on click scroll to last <.message/> in #chat
24 translations
Loading...
Live Block With Multiple Dependenciesbothreactivity
Body re-runs only when one of its tracked reads ($price or $quantity) changes
live put `${$price * $quantity}` into #total end
24 translations
Loading...
Live Derived Valuebothreactivity
Reactively update content whenever a tracked dependency changes
live put `Count: ${$count}` into me end
24 translations
Loading...
Log Elementdebugging
Log the current element to console
on click log me
24 translations
Loading...
Log Valuedebugging
Log a message to the console
on click log "Button clicked!"
24 translations
Loading...
Make Elementdom-manipulation
Create a new element dynamically
on click make a <div.card/> then put it into #container
24 translations
Loading...
Make Toast Elementtemplates
Create a new element, populate its content, and append it to the document
on click make a <div.toast/> then put 'Saved!' into it then put it at end of body
Safe property access using optional chaining (HyperFixi extension)
on click log my?.dataset?.customValue
24 translations
Loading...
POST With Method And Bodyasync
POST to an endpoint by passing method and body as fetch options
on click fetch /api/users with method:"POST", body:"name=Joe"
24 translations
Loading...
Pick Text Rangedom-manipulation
Select a text range within an input or contenteditable using the pick command
on click pick characters 0 to 5 of #note
24 translations
Loading...
Prevent Form Submitforms
Prevent form submission and validate
on submit halt the event call validateForm() if result is false log "Invalid form" end
24 translations
Loading...
Previous Elementnavigation
Select and modify previous sibling element
on click remove .highlight from previous <li/>
24 translations
Loading...
Put Afterdom-manipulation
Insert content after the current element
on click put "<p>New</p>" after me
24 translations
Loading...
Put Beforedom-manipulation
Insert content before the current element
on click put "<p>New</p>" before me
24 translations
Loading...
Put Contentdom-manipulation
Replace the content of the current element
on click put "Done!" into me
24 translations
Loading...
Reactive Array Mutationbothreactivity
Mutate a reactive array; live blocks reading it re-render automatically
on click call $items.push(`item ${$items.length + 1}`)
24 translations
Loading...
Read DOM-Scoped Variable From Another Elementbothreactivity
Read a ^name variable scoped to a specific element instead of walking up from `me`
on click put ^count on #host into me
24 translations
Loading...
Receive Custom Eventevents
Receive a custom event and update the receiving element's content
on hello put 'Got it!' into me
24 translations
Loading...
Removable Behaviorbehavior
Removes element on click with optional confirmation and fade effect. Use: install Removable(confirmRemoval: true, effect: "fade")
behavior Removable(triggerEl, confirmRemoval, effect)
init
if triggerEl is undefined
set triggerEl to me
end
end
on click from triggerEl
if confirmRemoval
js(me)
if (!window.confirm("Are you sure?")) return "cancel";
end
if it is "cancel"
halt
end
end
trigger removable:before
if effect is "fade"
transition opacity to 0 over 300ms
end
trigger removable:removed
remove me
end
end
24 translations
Loading...
Remove Classclass-manipulation
Remove a CSS class from the current element when clicked
on click remove .highlight from me
24 translations
Loading...
Remove Class From Allclass-manipulation
Remove a CSS class from all matching elements
on click remove .active from .items
24 translations
Loading...
Remove Elementdom-manipulation
Remove the current element from the DOM
on click remove me
24 translations
Loading...
Render Template With Datatemplates
Render a named template element with data, then insert the HTML into the DOM
on click render #user-list with users: $data then put it into #container
24 translations
Loading...
Repeat For Eachloops
Iterate over a collection
on click repeat for item in .items add .processed to item
24 translations
Loading...
Repeat Foreverloops
Infinite animation loop
on load repeat forever toggle .pulse wait 1s end
24 translations
Loading...
Repeat Timesloops
Repeat an action multiple times
on click repeat 3 times add "<p>Line</p>" to me
24 translations
Loading...
Repeat Until Eventloops
Repeat action while button is held
on mousedown repeat until event mouseup increment #counter wait 100ms end
24 translations
Loading...
Repeat While Conditionloops
Repeat while condition is true
on click repeat while #counter.innerText < 10 increment #counter wait 200ms end
24 translations
Loading...
Resizable Behaviorbehavior
Makes elements resizable by dragging. Use: install Resizable(minWidth: 100, minHeight: 100)
behavior Resizable(minWidth, minHeight, maxWidth, maxHeight)
on pointerdown(clientX, clientY) from me
halt the event
trigger resizable:start
measure width
set startWidth to it
measure height
set startHeight to it
set startX to clientX
set startY to clientY
repeat until event pointerup from document
wait for pointermove(clientX, clientY) from document
set newWidth to startWidth + clientX - startX
set newHeight to startHeight + clientY - startY
if newWidth < minWidth then set newWidth to minWidth end
if newWidth > maxWidth then set newWidth to maxWidth end
if newHeight < minHeight then set newHeight to minHeight end
if newHeight > maxHeight then set newHeight to maxHeight end
set my style.width to newWidth + "px"
set my style.height to newHeight + "px"
trigger resizable:resize
end
trigger resizable:end
end
end
24 translations
Loading...
Resize Handlerwindow-events
Handle window resize with debounce
on resize from window debounced at 200ms call adjustLayout()
24 translations
Loading...
SSE With Multiple Event Nameslokascriptrealtime
One SSE connection routing several named server events into the same target
on click set the *--primary-color of #theme to "#ff6600"
24 translations
Loading...
Set DOM-Scoped Variable On Parentbothreactivity
Declare a ^name variable on this element; descendants can read and write it
on load set ^count to 0
24 translations
Loading...
Set Opacitycss-styles
Set CSS opacity using possessive syntax
on click set my *opacity to 0.5
24 translations
Loading...
Set Styledom-manipulation
Set a CSS style property
on click set my *background to "red"
24 translations
Loading...
Set Text (Possessive Dot)lokascripthyperfixi-extensions
Set text content using possessive dot notation (HyperFixi extension)
on click set my.textContent to "Done!"
24 translations
Loading...
Set Text Contentdom-manipulation
Set the text content of an element by ID
on click set #output.innerText to "Hello World"
24 translations
Loading...
Set Transformcss-styles
Set CSS transform property
on click set my *transform to "rotate(45deg)"
24 translations
Loading...
Set innerHTML (Possessive Dot)lokascripthyperfixi-extensions
Set innerHTML using possessive dot notation (HyperFixi extension)
on click set my.innerHTML to "<strong>Updated!</strong>"
24 translations
Loading...
Settle Animationsanimation
Wait for CSS animations to complete
on click add .animate then settle then remove .animate
24 translations
Loading...
Show Elementvisibility
Show a hidden element
on click show #modal
24 translations
Loading...
Show With Transitionvisibility
Show element with opacity transition
on click show #modal with *opacity
24 translations
Loading...
Slide Toggleanimation
Slide panel open/closed
on click toggle .collapsed on next .panel transition *max-height over 300ms
24 translations
Loading...
Sortable Behaviorbehavior
Makes child elements reorderable via drag-and-drop. Use: install Sortable(handle: ".drag-handle")
behavior Sortable(dragClass)
init
if dragClass is undefined
set dragClass to "sorting"
end
end
on pointerdown(clientY) from me
set item to the closest <li/> to the target
if item is null
exit
end
halt the event
add .{dragClass} to item
trigger sortable:start on me
repeat until event pointerup from document
wait for pointermove(clientY) from document
trigger sortable:move on me
end
remove .{dragClass} from item
trigger sortable:end on me
end
end
24 translations
Loading...
Stagger Animationanimation
Staggered entrance animation
on load repeat for item in .item with index add .visible to item wait 100ms end
24 translations
Loading...
Submit Form As FormDataasync
Serialize the closest form as FormData and POST it
on submit fetch /api/submit with method:"POST", body:(closest <form/> as FormData)
24 translations
Loading...
Swap Contentdom-manipulation
Swap two elements in the DOM
on click swap #a with #b
24 translations
Loading...
Tab Navigationui-components
Basic tab switching with active state
on click remove .active from .tab add .active to me
24 translations
Loading...
Tab With Content Panelui-components
Tab that shows associated content panel
on click remove .active from .tab add .active to me hide .tab-panel show the next <div.tab-panel/>
24 translations
Loading...
Take Class From Siblings (Tabs)dom-manipulation
Take a class from sibling elements and apply it to the current one (canonical tabs idiom)
on click take .active from .tab-button for me
24 translations
Loading...
Tell Another Elementevents
Run a sequence of commands on another element using tell
on click tell #panel add .open then wait 200ms then add .visible
24 translations
Loading...
Tell Commandbehaviors
Tell another element to execute a command
on click tell #modal to show
24 translations
Loading...
Template Literal Interpolationtemplates
Use backtick template literals to interpolate values into HTML
on click set my innerHTML to `<li>${$item.name}</li>`
24 translations
Loading...
Toggle ARIA Expandedaccessibility
Toggle ARIA expanded state
on click toggle @aria-expanded on me toggle .open on next .panel
24 translations
Loading...
Toggle Classclass-manipulation
Toggle a CSS class on the current element when clicked
on click toggle .active
24 translations
Loading...
Toggle Class On Other Elementclass-manipulation
Toggle a CSS class on another element
on click toggle .open on #menu
24 translations
Loading...
Toggle Visibilityvisibility
Toggle the hidden attribute on an element
on click toggle @hidden on #panel
24 translations
Loading...
Transition Background Colorcss-styles
Animate background color change
on click transition *background-color to "blue" over 500ms
24 translations
Loading...
Transition Opacityanimation
Animate opacity then remove the element
on click transition opacity to 0 over 500ms then remove me
24 translations
Loading...
Transition Transformanimation
Animate transform property
on click transition transform to "scale(1.2)" over 300ms
24 translations
Loading...
Trigger Eventevents
Trigger a custom event when the element loads
on load trigger init
24 translations
Loading...
Two-Way Bind Two Inputsbothreactivity
Share a global between two inputs by binding both to it; edits in either propagate to the other
bind $name to #input-a then bind $name to #input-b
24 translations
Loading...
Two-Way Bindingdata
Update display as input changes
on input from #firstName set #greeting.innerText to "Hello, " + my value
24 translations
Loading...
Unless Conditioncontrol-flow
Execute unless condition is true
on click unless I match .disabled toggle .selected
24 translations
Loading...
Wait For Eventtiming
Wait for a DOM event to fire
on click wait for transitionend
24 translations
Loading...
Wait Then Executetiming
Wait for a duration before executing a command
on click wait 2s then remove me
24 translations
Loading...
Web Worker Definitionbothrealtime
Define a Web Worker in hyperscript and call its methods like a normal object
worker Calculator def add(a, b) return a + b end end
24 translations
Loading...
WebSocket Listenerbothrealtime
Open a WebSocket and route incoming messages into the DOM
socket ChatSocket ws://localhost:8080 on message put it into #chat end
24 translations
Loading...
WebSocket With Form Sendlokascriptrealtime
Open a WebSocket on an element; descendant forms serialize fields to JSON and ws-send on submit