Bind any DOM event directly in HTML:
<!-- Click -->
<button on:click="count++">Increment</button>
<button on:click="handleLogout()">Logout</button>
<!-- Input -->
<input on:input="search = $event.target.value" />
<input on:focus="focused = true" on:blur="focused = false" />
<!-- Keyboard -->
<input on:keydown.enter="submitForm()"
on:keydown.escape="cancel()" />
<!-- Mouse -->
<div on:mouseenter="hovered = true"
on:mouseleave="hovered = false">
Hover me
</div>
<!-- Custom events -->
<div on:custom-event="handleCustom($event.detail)"></div><!-- .prevent — calls preventDefault() -->
<form on:submit.prevent="handleSubmit()">
<!-- .stop — calls stopPropagation() -->
<button on:click.stop="handleClick()">
<!-- .once — listener fires only once -->
<button on:click.once="initializeApp()">
<!-- .self — only fires if target is the element itself -->
<div on:click.self="closeModal()">
<!-- .debounce — debounce the handler -->
<input on:input.debounce.300="search($event.target.value)" />
<!-- .throttle — throttle the handler -->
<div on:scroll.throttle.100="handleScroll()">
<!-- Key modifiers -->
<input on:keydown.enter="submit()"
on:keydown.ctrl.s="save()"
on:keydown.shift.delete="deleteAll()" />
<!-- Combine modifiers -->
<form on:submit.prevent.once="register()">Inside any on:* handler, $event refers to the native DOM event:
<input on:input="name = $event.target.value" />
<div on:click="handleClick($event.clientX, $event.clientY)"></div><input on:focus="$el.select()" />
<div on:click="$el.classList.toggle('expanded')"></div><!-- Run when element is inserted into the DOM -->
<div on:mounted="initChart($el)">
<canvas ref="chart"></canvas>
</div>
<!-- Run when element is removed from the DOM -->
<div on:unmounted="cleanup()"></div>
<!-- Run once when the element is first processed -->
<div on:init="fetchInitialData()"></div>
<!-- Run every time a bound value changes -->
<div on:updated="logChange()"></div>| Hook | When |
|---|---|
on:init |
Directive first processed |
on:mounted |
Element inserted into visible DOM |
on:updated |
Any reactive dependency changed |
on:unmounted |
Element removed from DOM |
on:error |
Any error in this element's subtree |
Next: Dynamic Styling →