Programmatically fired events not working with event delegation

后端 未结 2 1706
孤城傲影
孤城傲影 2021-02-06 07:22

Would really appreciate if anyone can help me figure out why I am unable to fire events programmatically when using event delegation in MooTools (from the Element.Delegati

2条回答
  •  北恋
    北恋 (楼主)
    2021-02-06 07:51

    this won't work too well 'as is'. the problem with event bubbling (and with programmatic firing of events) is that it may need the event object to be 'real' in order for it to contain event.target that is being matched against the relay string. also, document.id("color").fireEvent() won't work as color itself has no event attached to it.

    to get around this, you fake the event on the parent listener by passing an event object that contains the target element like so:

    document.id("listener").fireEvent("change", {
        target: document.id("color")
    });
    

    view in action: http://www.jsfiddle.net/xZFqp/1/

    if you do things like event.stop in your callback function then you need to pass on {target: document.id("color"), stop: Function.from} and so forth for any event methods you may be referencing but the event delegation code is only interested in target for now.

提交回复
热议问题