admin管理员组文章数量:1344568
In JavaScript, the addEventListener() method is used like this:
object.addEventListener("click", myScript);
In Scala.js: I have a canvas, and I want to listen to clicks only on the canvas, not the entire document. In the Scala.js.dom library, addEventListener is defined as:
def addEventListener(`type`: String, listener: js.Function1[Event, _], useCapture: Boolean = ???): Unit = ???
I'm not sure what "useCapture" refers to. But I tried:
dom.document.getElementById("canvas").addEventListener("click", {
(e:dom.MouseEvent) => { /*do something*/ }
}, false)
And the error message I got:
found : org.scalajs.dom.MouseEvent => Unit
required: scala.scalajs.js.Function1[org.scalajs.dom.Event, _]
Can someone explain what "useCapture" refers to, and how to correctly use addEventListener in Scala.js?
In JavaScript, the addEventListener() method is used like this:
object.addEventListener("click", myScript);
In Scala.js: I have a canvas, and I want to listen to clicks only on the canvas, not the entire document. In the Scala.js.dom library, addEventListener is defined as:
def addEventListener(`type`: String, listener: js.Function1[Event, _], useCapture: Boolean = ???): Unit = ???
I'm not sure what "useCapture" refers to. But I tried:
dom.document.getElementById("canvas").addEventListener("click", {
(e:dom.MouseEvent) => { /*do something*/ }
}, false)
And the error message I got:
found : org.scalajs.dom.MouseEvent => Unit
required: scala.scalajs.js.Function1[org.scalajs.dom.Event, _]
Can someone explain what "useCapture" refers to, and how to correctly use addEventListener in Scala.js?
Share Improve this question asked Jul 24, 2014 at 14:27 user3025403user3025403 1,0803 gold badges22 silver badges33 bronze badges 1-
Regarding
useCapture
, the following snippet is from the Mozilla docs: "indicates that events of this type will be dispatched to the registered listener, before being dispatched to any EventTarget beneath it in the DOM tree." – Matthias Braun Commented May 3, 2017 at 14:36
2 Answers
Reset to default 10The error message you get is a perfectly normal type error: addEventListener
expects a js.Function1[dom.Event, _]
, but you're giving it a js.Function1[dom.MouseEvent, _]
. Since the first argument is in contravariant position, this does not typecheck.
There are two solutions: either you make your function take a dom.Event
, that you then cast to dom.MouseEvent
, like this:
canvas.addEventListener("click", { (e0: dom.Event) =>
val e = e0.asInstanceOf[dom.MouseEvent]
...
}, false)
or you use onclick
which is more precisely typed:
canvas.onclick = { (e: dom.MouseEvent) =>
...
}
Event capture is the process by which an EventListener registered on an ancestor of the event's target can intercept events of a given type before they are received by the event's target. Capture operates from the top of the tree, generally the Document, downward, making it the symmetrical opposite of bubbling which is described below. The chain of EventTargets from the top of the tree to the event's target is determined before the initial dispatch of the event. If modifications occur to the tree during event processing, event flow will proceed based on the initial state of the tree..
http://www.w3/TR/DOM-Level-2-Events/events.html#Events-flow-basic
window.addEventListener("click", function(){console.log('something1')}, false);
window.addEventListener("click", function(){console.log('something2')}, true);
The order will be
something 2 (defined first, using capture=true)
something 1 (defined second using capture=true)
Ref 2
Note on the second ref: The order is not guaranteed!
capture phase
The process by which an event can be handled by one of the target ancestors before being handled by the target node.
REF 3
本文标签: javascriptScalajs Using addEventListener to add events to objectsStack Overflow
版权声明:本文标题:javascript - Scala.js: Using addEventListener to add events to objects - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743783755a2538306.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论