作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 JSX 中,可以将多个事件绑定(bind)到一个 DOM 元素,如下所示:
<input {...inputEvents}>
<input on:input={inputHandler}>
<input bind:this={myInput}>
myInput.oninput = (event) => {
// do something
}
myInput.addEventListener('click', (event) => {
// do something
})
最佳答案
如果您需要将相同或相似的事件处理程序集附加到各种元素,那么您可以使用带有 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/
我是一名优秀的程序员,十分优秀!