0
私は次のカスタムDojoウィジェットがあります。このように宣言されてdijit/_HasDropDownからウィジェットを囲んでプログラム的に継承するdojoウィジェットを開く方法
/**
* Javascript for ExpandableSearchComponent
*/
define([ "dojo/_base/declare", "dijit/_WidgetBase", "dijit/_TemplatedMixin",
"dojo/text!./templates/ExpandableSearchComponent.html",
"dijit/TitlePane", "dijit/_WidgetsInTemplateMixin", "dijit/registry",
"dojo/on", "dojo/aspect", "dojo/_base/lang" ], function(declare,
_WidgetBase, _TemplatedMixin, template, TitlePane,
_WidgetsInTemplateMixin, registry, on, aspect, lang) {
return declare([ _WidgetBase, _TemplatedMixin, _WidgetsInTemplateMixin ], {
templateString : template,
prefixTitle : "",
containedWidgetId : "",
that : this,
startup : function() {
this.inherited(arguments);
var containedWidget = registry.byId(this.containedWidgetId);
var titlePane = registry.byId("titleNodePane");
this.own(on(titlePane, "Show", function() {
containedWidget.openDropDown();
}.bind(containedWidget)));
//Other logic
}
});
});
:
<div data-dojo-type="js/widgets/ExpandableSearchComponent"
data-dojo-props="prefixTitle: 'Name: ', containedWidgetId: 'machineSearchView.name'">
<!-- Other elements including the machineNameStore-->
<div data-dojo-type="dijit/form/ComboBox"
data-dojo-props="store:machineNameStore, searchAttr:'name', value:'${MachineName}'"
name="machineSearchView.name" id="machineSearchView.name"></div>
</div>
それは1つの事を除いて、ほぼ完璧に動作します。このコードで
<div class="${baseClass}">
<div data-dojo-type="dijit/TitlePane" data-dojo-props="title:'${prefixTitle}', open:false" id="titleNodePane">
<div id="container"
class="${baseClass}Container"
data-dojo-attach-point="containerNode"></div>
</div>
</div>
を:on(titlePane, "Show", function(){})
。これは、_HasDropDownを含む包含ウィジェットのドロップダウンを開くためのものです。 _HasDropDownの139行目でエラーUncaught TypeError: Cannot read property 'domNode' of null
が表示されます。どうやら、this.dropDownは、タイトルパネルが完全に展開されてから、openDropDown()
に壊れるまで設定されていません。
これを修正する方法はありますか?
openDropDown()の代わりにloadAndOpenDropDown()を呼び出そうとしましたか? – pgianna
@pgiannaそれを修正しました。私はそれが簡単だとは信じられません。私はあなたの25ポイントを与えることができるように答えとして投稿することができますか? – Nzall