javascript - 如何在 Svelte 中动态绑定(bind)事件?

标签 javascript svelte

在 JSX 中,可以将多个事件绑定(bind)到一个 DOM 元素,如下所示:

<input {...inputEvents}>

在 Svelte 中,这是手动完成的。
<input on:input={inputHandler}>

当您需要将多个处理程序(输入、模糊、焦点)添加到表单的多个输入时,这会变得乏味。

我发现在 Svelte 中解决这个问题的唯一方法是使用 refs。

例如:
<input bind:this={myInput}>

然后在某个地方这样做:
myInput.oninput = (event) => {
  // do something
}

或者:
myInput.addEventListener('click', (event) => {
  // do something
})

有没有更好的方法在 Svelte 中动态绑定(bind)事件?

最佳答案

如果您需要将相同或相似的事件处理程序集附加到各种元素,那么您可以使用带有 use:action 的“操作”。 (引用:https://svelte.dev/docs#template-syntax-element-directives-use-action)
这是一个例子:

<script>
  function manyHandlers(element){
    element.addEventListener("click", ev => {...})
    element.addEventListener("focus", ev => {...})
    element.addEventListener("blur", ev => {...})
    ...
  }
</script>

<form>
  <input use:manyHandlers>
  <textarea use:manyHandlers></textarea>
  <!-- and so on... -->
</form>
您可以将附加参数传递给 use:___ 中指定的函数。 ,例如控制附加哪组事件处理程序。有关其工作原理,请参阅上述文档引用。
此外,如评论中所述,您可以利用事件冒泡并将事件处理程序附加到父元素(例如:上例中的 <form> 元素)并使用 event.target对接收到事件的元素进行特定处理。

关于javascript - 如何在 Svelte 中动态绑定(bind)事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60934557/

相关文章:

javascript - 在表格中,选择 tr#myId 和下一个

javascript - svelte electron 中的 JS 文件中不能需要 Node 模块

javascript - 是否可以直接在 Svelte 中渲染 SVG 元素?

javascript - Svelte 给我 'Uncaught ReferenceError: require is not defined'

javascript - IBM SBT :Expectation Failed error

javascript - 显示 : none container 的 SpectrumJS、拖动器和 slider 位置问题

javascript - 500(内部服务器错误)jQuery ajax ui 自动完成 codeigniter

javascript - 如何设置:before psudo property for a group of css styles

javascript - 如何在 Vercel 上的 SvelteKit 应用程序中创建 Web Worker?

javascript - 如何解决两个事件之间的碰撞,单击外部并单击按钮以关闭 svelte 工具包中的菜单?