<div dojoType="dojo.Dialog" id="alarmCatDialog" bgColor="#FFFFFF" bgOpacity="0.4" toggle="standard"> <div class='dijitInline'> <input type='input' class='dateWidgetInput' dojoAttachPoint='numberOfDateNode' selected="true"> </div>
如何显示这个对话框我试过dijit.byId(‘alarmCatDialog’).show();
上面的代码是一个模板,我从.js文件中调用了dijit.byId(‘alarmCatDialog’).show().
dojo.attr(this.numberOfDateNode)这段代码有效,我得到了数据.但如果我将dojoattachpoint改为id,那么我尝试dijit.byId(‘numberOfDateNode’)将无效;
解决方法
您的numberOfDateNode是一个普通的DOM节点,而不是widget / dijit,即扩展dijit / _Widget的javascript对象,这是您无法通过dijit.byId(“numberOfDateNode”)获取对它的引用的原因.使用dojo.byId(“numberOfDateNode”)代替,你就完成了.
在dijit模板中使用dojoAttachPoint或其HTML5有效版本数据-dojo-attach-point将对DOM节点或子dijit的引用附加到dijit javascript对象,这就是dijit.byId(‘alarmCatDialog’)的原因.numberOfDateNode具有对< input type ='input'class ='dateWidgetInput'... />的引用.
使用data-dojo-attach-point的主要原因是:
>您可以创建多个dijit实例,因此您的模板无法通过ID识别节点/ dijit,因为您将拥有多个具有相同ID的节点/ dijit>这是一种优雅的声明方式,所以你的代码不会充满dijit.byId / dojo.byId.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。