DOM events
on:eventname={handler}
on:eventname|modifiers={handler}
你可以使用on:的指令来监听 DOM 事件:
<script>let count = 0;function handleClick(event) {count += 1;}</script><button on:click={handleClick}>count: {count}</button>
内联方式声明的处理函数,并不会影响性能。与其他属性一样,为了可以语法高亮显示,指令的值可以用引号包裹。
<button on:click="{() => count += 1}">count: {count}</button>
使用 | 字符来向DOM事件添加修饰符。
可以使用以下修饰符:
preventDefault: 在 handeler 执行前,调用event.preventDefault()stopPropagation: 调用event.stopPropagation(),阻止事件冒泡passive: 提高触摸/滚动事件的滚动性能( Svelte 会在支持地方默认使用它)capture:在捕获阶段而不是冒泡阶段,触发事件处理函数once: 事件处理函数被执一次后会被移除
修饰符可以使用 | 链接起来:on:click|once|capture={...}
<form on:submit|preventDefault={handleSubmit}><!-- the `submit` event's default is prevented,so the page won't reload --></form>
如果 on: 指令没有值,则组件会转发这个事件,意味着组件的使用者,可以监听这个事件。
<button on:click>The component itself will emit the click event</button>
对于同样的事件,可以有多个事件监听者。
<script>let counter = 0;function increment() {counter = counter + 1;}function track(event) {trackEvent(event)}</script><button on:click={increment} on:click={track}>Click me!</button>
