当前位置 : 主页 > 网页制作 > Dojo >

dojoAttachpoint和id之间的区别

来源:互联网 收集:自由互联 发布时间:2021-06-15
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 如何显示这个对话
<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.

网友评论