dojo小部件上未触发自定义事件

7lrncoxx  于 2022-12-16  发布在  Dojo
关注(0)|答案(2)|浏览(216)

我有dojo自定义小部件.
我需要从自定义小部件发出一个事件,这是我添加事件侦听器的代码

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script type="text/javascript">
        var dojoConfig = {
            async: true,
            parseOnLoad: true,
            isDebug : true,
            packages:[
                {   name:"custom",
                    location:"/Test/js"
                }
            ]
        };
    </script>
    <script src="//localhost:8080/dojo1.9.0/dojo/dojo.js"></script>
</head>
<body>
<script>
    require(["custom/MyWidget","dojo/on","dojo/dom-construct","dojo/_base/window","dojo/domReady!"],function(MyWidget,on,domconstruct,window){
        var mywidget = new MyWidget();
        mywidget.startup();
        domconstruct.place(mywidget.domNode,window.body(),"after");

        on(mywidget,"customevent",function(data){
            console.log( " received notification "+data );
        });
    });
</script>
</body>
</html>

和小部件如下

define([
    "dojo/_base/declare",
    "dijit/_WidgetBase",
    "dijit/_OnDijitClickMixin",
    "dijit/_TemplatedMixin",
    "dojo/text!./widget.html",
    "dojo/on",
    "dojo/_base/lang"
], function (declare, _WidgetBase, _OnDijitClickMixin, _TemplatedMixin, template,on,lang) {

    return declare([_WidgetBase, _OnDijitClickMixin, _TemplatedMixin], {
        templateString: template,
        //  your custom code goes here
        _onClick:function()
        {

        },

        postCreate : function ()
        {
            on(this.searchtextbox,"click",lang.hitch(this,"sendEvent"));

        },
        sendEvent : function(event)
        {
            console.log( "Click event in widget "+event );
            this.emit("customevent",event.x)
        }
    });

});

//Widget.html

<div class="${baseClass}" data-dojo-attach-point="searchtextbox">
    <p>
        here your widget
    </p>
</div>

问题是线路
this.emit("customevent",event.x)正在引发错误

sczxawaw

sczxawaw1#

小部件事件

你不应该使用dojo/on来添加事件处理器到widget,它只用于DOM节点。如果你从dijit/_WidgetBase扩展(像你做的那样),那么有一个名为on()的方法可以使用,例如:

myWidget.on("customevent", function(data) {
    console.log( " received notification "+data );
});

小部件扩展点

我不知道emit()函数是做什么的,但看起来问题就在这里。根据文档,你应该用普通函数来编写扩展点。例如:

postCreate : function () {
    on(this.searchtextbox,"click",lang.hitch(this, "_onClick"));
},
_onClick: function(event) {
    // This is where you put your code
    console.log( "Click event in widget "+event );
    this.onCustomEvent(event.x);
},
onCustomEvent: function() {
     // This can be left empty, it will be used as the extension point
}

在本例中,您将把click事件绑定到_onClick()函数,该函数又使用正确的参数调用onCustomEvent()。此函数供公共使用,可用于绑定自定义事件处理程序。
这是full example

rfbsl7qr

rfbsl7qr2#

emit方法的第二个参数应该是一个对象,但我没有向它发送对象。

sendEvent : function(event)
        {
            console.log( "Click event in widget "+event );
            this.emit("customevent",**event**)
        }

相关问题