@ -7,10 +7,12 @@ As well as attributes, elements can have _directives_, which control the element
## on:_eventname_
## on:_eventname_
```svelte
```svelte
<!--- copy: false --->
on:eventname={handler}
on:eventname={handler}
```
```
```svelte
```svelte
<!--- copy: false --->
on:eventname|modifiers={handler}
on:eventname|modifiers={handler}
```
```
@ -72,7 +74,6 @@ If the `on:` directive is used without a value, the component will _forward_ the
It's possible to have multiple event listeners for the same event:
It's possible to have multiple event listeners for the same event:
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
let counter = 0;
let counter = 0;
function increment() {
function increment() {
@ -91,6 +92,7 @@ It's possible to have multiple event listeners for the same event:
## bind:_property_
## bind:_property_
```svelte
```svelte
<!--- copy: false --->
bind:property={variable}
bind:property={variable}
```
```
@ -186,6 +188,8 @@ Elements with the `contenteditable` attribute support the following bindings:
There are slight differences between each of these, read more about them [here](https://developer.mozilla.org/en-US/docs/Web/API/Node/textContent#Differences_from_innerText).
There are slight differences between each of these, read more about them [here](https://developer.mozilla.org/en-US/docs/Web/API/Node/textContent#Differences_from_innerText).
<!-- for some reason puts the comment and html on same line -->
<!-- prettier-ignore -->
```svelte
```svelte
<divcontenteditable="true"bind:innerHTML={html}/>
<divcontenteditable="true"bind:innerHTML={html}/>
```
```
@ -273,13 +277,13 @@ Block-level elements have 4 read-only bindings, measured using a technique simil
## bind:group
## bind:group
```svelte
```svelte
<!--- copy: false --->
bind:group={variable}
bind:group={variable}
```
```
Inputs that work together can use `bind:group`.
Inputs that work together can use `bind:group`.
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
let tortilla = 'Plain';
let tortilla = 'Plain';
@ -304,13 +308,13 @@ Inputs that work together can use `bind:group`.
## bind:this
## bind:this
```svelte
```svelte
<!--- copy: false --->
bind:this={dom_node}
bind:this={dom_node}
```
```
To get a reference to a DOM node, use `bind:this`.
To get a reference to a DOM node, use `bind:this`.
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
import { onMount } from 'svelte';
import { onMount } from 'svelte';
@ -329,10 +333,12 @@ To get a reference to a DOM node, use `bind:this`.
## class:_name_
## class:_name_
```svelte
```svelte
<!--- copy: false --->
class:name={value}
class:name={value}
```
```
```svelte
```svelte
<!--- copy: false --->
class:name
class:name
```
```
@ -393,14 +399,17 @@ When `style:` directives are combined with `style` attributes, the directives wi
Actions are functions that are called when an element is created. They can return an object with a `destroy` method that is called after the element is unmounted:
Actions are functions that are called when an element is created. They can return an object with a `destroy` method that is called after the element is unmounted:
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
/** @type {import('svelte/action').Action} */
/** @type {import('svelte/action').Action} */
function foo(node) {
function foo(node) {
@ -433,7 +441,6 @@ An action can have a parameter. If the returned value has an `update` method, it
> Don't worry about the fact that we're redeclaring the `foo` function for every component instance — Svelte will hoist any functions that don't depend on local state out of the component definition.
> Don't worry about the fact that we're redeclaring the `foo` function for every component instance — Svelte will hoist any functions that don't depend on local state out of the component definition.
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
export let bar;
export let bar;
@ -461,30 +468,37 @@ Read more in the [`svelte/action`](/docs/svelte-action) page.
@ -61,9 +61,7 @@ Note that the value of a `writable` is lost when it is destroyed, for example wh
Creates a store whose value cannot be set from 'outside', the first argument is the store's initial value, and the second argument to `readable` is the same as the second argument to `writable`.
Creates a store whose value cannot be set from 'outside', the first argument is the store's initial value, and the second argument to `readable` is the same as the second argument to `writable`.
```js
```ts
<!--- file: App.svelte --->
// ---cut---
import { readable } from 'svelte/store';
import { readable } from 'svelte/store';
const time = readable(new Date(), (set) => {
const time = readable(new Date(), (set) => {
@ -114,7 +112,7 @@ The callback can set a value asynchronously by accepting a second argument, `set
In this case, you can also pass a third argument to `derived` — the initial value of the derived store before `set` or `update` is first called. If no initial value is specified, the store's initial value will be `undefined`.
In this case, you can also pass a third argument to `derived` — the initial value of the derived store before `set` or `update` is first called. If no initial value is specified, the store's initial value will be `undefined`.
Actions are functions that are called when an element is created. They can return an object with a `destroy` method that is called after the element is unmounted:
Actions are functions that are called when an element is created. They can return an object with a `destroy` method that is called after the element is unmounted:
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
/** @type {import('svelte/action').Action} */
/** @type {import('svelte/action').Action} */
function foo(node) {
function foo(node) {
@ -27,7 +26,6 @@ An action can have a parameter. If the returned value has an `update` method, it
> Don't worry that we're redeclaring the `foo` function for every component instance — Svelte will hoist any functions that don't depend on local state out of the component definition.
> Don't worry that we're redeclaring the `foo` function for every component instance — Svelte will hoist any functions that don't depend on local state out of the component definition.
```svelte
```svelte
<!--- file: App.svelte --->
<script>
<script>
/** @type {string} */
/** @type {string} */
export let bar;
export let bar;
@ -56,7 +54,6 @@ An action can have a parameter. If the returned value has an `update` method, it
Sometimes actions emit custom events and apply custom attributes to the element they are applied to. To support this, actions typed with `Action` or `ActionReturn` type can have a last parameter, `Attributes`:
Sometimes actions emit custom events and apply custom attributes to the element they are applied to. To support this, actions typed with `Action` or `ActionReturn` type can have a last parameter, `Attributes`:
@ -90,7 +90,7 @@ Each `markup`, `script` or `style` function must return an object (or a Promise
> Preprocessor functions should return a `map` object whenever possible or else debugging becomes harder as stack traces can't link to the original code correctly.
> Preprocessor functions should return a `map` object whenever possible or else debugging becomes harder as stack traces can't link to the original code correctly.
If a `dependencies` array is returned, it will be included in the result object. This is used by packages like [vite-plugin-svelte](https://github.com/sveltejs/vite-plugin-svelte) and [rollup-plugin-svelte](https://github.com/sveltejs/rollup-plugin-svelte) to watch additional files for changes, in the case where your `<style>` tag has an `@import` (for example).
If a `dependencies` array is returned, it will be included in the result object. This is used by packages like [vite-plugin-svelte](https://github.com/sveltejs/vite-plugin-svelte) and [rollup-plugin-svelte](https://github.com/sveltejs/rollup-plugin-svelte) to watch additional files for changes, in the case where your `<style>` tag has an `@import` (for example).
```ts
```ts
/// file: preprocess-sass.js
// @filename: ambient.d.ts
// @filename: ambient.d.ts
declare global {
declare global {
var source: string;
var source: string;
@ -204,6 +205,7 @@ Multiple preprocessors can be used together. The output of the first becomes the
> In Svelte 3, all `markup` functions ran first, then all `script` and then all `style` preprocessors. This order was changed in Svelte 4.
> In Svelte 3, all `markup` functions ran first, then all `script` and then all `style` preprocessors. This order was changed in Svelte 4.
```js
```js
/// file: multiple-preprocessor.js
// @errors: 2322
// @errors: 2322
// @filename: ambient.d.ts
// @filename: ambient.d.ts
declare global {
declare global {
@ -255,6 +257,7 @@ The `walk` function provides a way to walk the abstract syntax trees generated b
The walker takes an abstract syntax tree to walk and an object with two optional methods: `enter` and `leave`. For each node, `enter` is called (if present). Then, unless `this.skip()` is called during `enter`, each of the children are traversed, and then `leave` is called on the node.
The walker takes an abstract syntax tree to walk and an object with two optional methods: `enter` and `leave`. For each node, `enter` is called (if present). Then, unless `this.skip()` is called during `enter`, each of the children are traversed, and then `leave` is called on the node.