javascript - 如何在 Svelte 中动态绑定事件?
问题描述
在 JSX 中,可以将多个事件绑定到一个 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 中动态绑定事件?
解决方案
如果您需要将相同或相似的事件处理程序集附加到各种元素,那么您可以使用“actions” 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
接收事件的元素进行特定处理。
推荐阅读
- java - 我有一个问题,我遇到了这样的错误 [[Ljava.lang.Integer;@26f0a63f]
- docker - docker-compose up 适用于本地,而不是部署
- spring - Guice 和(移至)Spring 的比较
- c - 使用scanf时如何检查预期的输入数量何时停止?
- angular - 为什么自定义验证不适用于反应形式?
- node.js - 用 Jest 测试 Express 时,有没有办法解决这个“TypeError:express.json 不是函数”?
- google-bigquery - 如何为 BigQuery 中的数组创建 DDL
- php - 百分比格式化程序
- python - 连接两个 DataFrame,但仅适用于 Python 中的常见值
- git - 导出特定日期范围内 Azure Repos 中特定文件夹中所有文件的 git 历史记录