ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Dojo入门:dojo中的事件处理

2019-08-31 10:56:34  阅读:180  来源: 互联网

标签:function 事件处理 Dojo dojo connect btn 方法


 

 

JS为DOM添加事件

在原生的环境下,为DOM添加事件处理函数有多种方法:

<input type="button" name="btn" value="点击…" id="btn" onclick="btnClick" />

或者使用以下方法:

复制代码
    <input type="button" name="btn" value="点击…" id="btn" />
    <script type="text/javascript">
        function btnClick() {
            alert("我被点击了");
        }
        document.getElementById("btn").onclick = btnClick;</script>
复制代码

 

以上这两种方法存在明显的弊端:每一个事件只能指定一个事件处理函数,另外,如果要移除一个事件处理函数,似乎只能使用:

document.getElementById("btn").onclick = null;

 

或者

document.getElementById("btn").onclick = "";

 

这种方式极不利于模块化编程。W3C DOM Level2 标准有了新的事件模型,新的事件模型允许为事件添加多个处理方法,并加入了事件冒泡机制。

使用新的事件模型来添加事件处理方法:

复制代码
    <input type="button" name="btn" value="点击…" id="btn" />
    <script type="text/javascript">
        function btnClick() {
            alert("我被点击了");
        }
        document.getElementById("btn").addEventListener("click", btnClick);
    </script>
复制代码

 

移除一个事件处理方法:

document.getElementById("btn").removeEventListener("click", btnClick);

 

 

dojo事件处理

dojo使用connect方法为DOM添加事件处理函数。

复制代码
    <script type="text/javascript">
        function btnClick() {
            alert("我被点击了");
        }
        var btn = dojo.byId("btn");
        dojo.connect(btn, "onclick", btnClick);
    </script>
复制代码

 

dojo.connect方法的官方解释:dojo.connect is the core event handling and delegation method in Dojo. It allows one function to "listen in" on the execution of any other, triggering the second whenever the first is called. Many listeners may be attached to a function, and source functions may be either regular function calls or DOM events.

翻译过来大概是:dojo.connect 是dojo中事件处理和委托方法的核心。它允许一个方法去“监听”另一个方法的执行,当被监听方法被调用的时候触发监听方法。一个方法可以附加很多监听者,这个源方法可以是常规的方法或DOM事件。

这么说来,connect还可以监听别的方法的执行,下面我们来做一个测试:

复制代码
    <input type="button" name="btn" value="点击…" id="btn" />
    <script type="text/javascript">
        function sayHello() {
            alert("Hello ");
        }

        function sayWorld() {
            alert("world~");
        }

        dojo.addOnLoad(function () {
            var btn = dojo.byId("btn");
            btn.addEventListener("click", sayHello);
            dojo.connect("sayHello", sayWorld);
        });
    </script>
复制代码

 

这段代码的执行效果是当按钮被点击之后,先弹出一个Hello字符串,当把对话框关掉以后,会弹出另外一个world对话框。

可能不是每个人都喜欢这种处理方式,但这样以来,代码会更易于阅读。

如果需要移除一个事件,则需要调用dojo.disconnect方法,这个方法需要一个dojo.connect方法的返回值作为参数:

        var handle = dojo.connect(btn, "onclick", btnClick);
        dojo.disconnect(handle);

 

订阅和发布

这是dojo很值得关注的一个功能,它使得各个dojo组件可以方便的交互。这个功能使用起来很方便:

复制代码
    <input type="text" name="txtMessage" value="" id="txtMessage" />
    <input type="button" name="btn" value="发布…" id="btnPublish" />
    <script type="text/javascript">
        dojo.addOnLoad(function () {
            //订阅MesagePublish主题
            dojo.subscribe("MessagePublish", function (msg) {
                alert(msg);
            });

            var btnPublish = dojo.byId("btnPublish");
            dojo.connect(btnPublish, "onclick", function () {
                dojo.publish("MessagePublish", dojo.byId("txtMessage").value);
            });
        });
    </script>
复制代码

 

以上代码的运行效果如图:

如要取消一个订阅,需要使用dojo.unsubscribe方法,这个方法需要一个由dojo.subscribe返回的句柄,其处理方式和dojo.connect、dojo.disconnect 的方式一样。

如果认为此文对您有帮助,别忘了支持一下哦!

声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。转载时请在文章页面明显位置给出原文链接。

标签:function,事件处理,Dojo,dojo,connect,btn,方法
来源: https://www.cnblogs.com/Jeely/p/11438196.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有