mirror of https://github.com/sveltejs/svelte
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
27 lines
931 B
27 lines
931 B
6 years ago
|
---
|
||
|
title: Event modifiers
|
||
|
---
|
||
|
|
||
|
DOM event handlers can have *modifiers* that alter their behaviour. For example, a handler with a `once` modifier will only run a single time:
|
||
|
|
||
|
```html
|
||
|
<script>
|
||
|
function handleClick() {
|
||
|
alert('no more alerts')
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<button on:click|once={handleClick}>
|
||
|
Click me
|
||
|
</button>
|
||
|
```
|
||
|
|
||
|
The full list of modifiers:
|
||
|
|
||
|
* `preventDefault` — calls `event.preventDefault()` before running the handler. Useful for e.g. client-side form handling
|
||
|
* `stopPropagation` — calls `event.stopPropagation()`, preventing the event reaching the next element
|
||
|
* `passive` — improves scrolling performance on touch/wheel events (Svelte will add it automatically where it's safe to do so)
|
||
|
* `capture` — fires the handler during the *capture* phase instead of the *bubbling* phase
|
||
|
* `once` — remove the handler after the first time it runs
|
||
|
|
||
|
You can chain modifiers together, e.g. `on:click|once|capture={...}`.
|