【发布时间】:2011-02-03 09:41:14
【问题描述】:
我似乎无法正确地将 onchange 事件附加到 dijit.form.Select 小部件。但是,我是 Web 开发的新手,所以我可能会做一些完全愚蠢的事情(尽管,据我所知(我已经阅读了我能找到的所有文档)我不是)。我确保 body 类与 dojo 主题相匹配,我使用 dojo.require() 来处理我使用的所有小部件(和 dojo.parser),而且仍然是 nada。我使用的代码是:
dojo.addOnLoad(function () {
var _query = dojo.query('.toggle');
for (var i in _query) {
dojo.connect(_query[i], 'onchange', function (ev) {
console.log(ev + ' fired onchange');
});
}
});
任何帮助都将不胜感激。
补充:在深入了解 dijit 如何呈现小部件的内部结构后,我发现当我将 dojoType='dijit.form.Select' 属性-值对添加到我的 html 元素(以声明方式执行此操作)时,dijit 实际上会呈现单行两列表。该表的第一个元素是一个跨度(具有类 dijitSelectLabel),我假设它只显示选定(或默认)元素。它的第二个元素似乎是一个呈现为向下箭头的按钮,它可以切换菜单项的显示以响应某些 DOM 事件。此外(我认为这很漂亮),dijit 实际上并没有将选择选项放置在 DOM 树中,直到其中一个事件被触发。在新的页面加载之后(在我单击任何内容之前),我在 firebug 中查看了 HTML,而第二个选项在任何地方都找不到。然后,一旦我单击箭头按钮,就会出现 dijit.Menu 小部件,dijit 将 dijit.Menu 粘贴到 body 节点的末尾;在我单击其他位置后,Menu 小部件仍然是正文的 lastChild,现在它只是隐藏并且未附加到表单。选择小部件。
如果我只想根据用户选择的项目在 DOM 树中放置一个不同的 dijit.form 小部件,真的会这么复杂吗?
结论:
原来这是一个大小写问题。
dojo.connect(widget_obj, 'onChange', function_obj);
有效,而
dojo.connect(widget_obj, 'onchange', function_obj);
没有。所以我是对的,我完全是愚蠢的。我假设因为在将 html 标记作为属性放入其中时,全小写版本有效,所以 Dojo 会以同样的方式对待它。这是有道理的,因为 dijit.form.Select 没有 .onchange 属性,但有 .onChange 属性。 (我最终坚持使用 .Select 而不是 .FilteringSelect ,因为我不会给我的用户任何他们可以输入内容的印象。)所以,我会回答你们中的哪一个(因为你们俩在你的帖子中有 onChange,我想我只是太缺乏经验,没有意识到这个案子很重要)?
【问题讨论】:
标签: javascript select dojo onchange