钛合金:从所需视图获取当前窗口

时间:2016-06-10 07:59:13

标签: titanium titanium-mobile titanium-alloy appcelerator-titanium titanium-android

我有以下代码(index.js):



<Alloy>
  <Window id="home" >
    <View id="formulaire">
	  <Require type="view" id="etape_1_form" src="form/etape_1" />
	</View>
  </Window>
</Alloy>
&#13;
&#13;
&#13;

在etape_1_form.xml上,我必须使用以下的选择器窗口小部件:danielhanold.pickerwidget

这是在etape_1_form.js(控制器)中使用此小部件的简单方法:

&#13;
&#13;
Alloy.createWidget('danielhanold.pickerWidget', {
  id: 'mySingleColumn',
  outerView: $.home,
  hideNavBar: false,
  type: 'single-column',
  selectedValues: [20],
  pickerValues: [{10: 'Auburn', 20: 'Bald', 30: 'Black', 40: 'Blond', 50: 'Brown'}],
  onDone: function(e) {
    // Do something
  },
});

$.form_win.open();
&#13;
&#13;
&#13;

现在不是打开一个选择器,而是抛出一个错误,因为我无法从这一行访问当前窗口:

outerView: $.home
The error : "undefined is not an object (evaluating 'outerView.add')

当我将选择器移动到index.js(主控制器)时,选择器工作,但我有许多必需的表单,并希望组织我的代码,所以我喜欢把每个表单js代码放在它的控制器文件中。

那么我如何从所需视图访问$ .home窗口?谢谢你的帮助。

1 个答案:

答案 0 :(得分:1)

不,你不能直接。

但你可以使用&#34;全局&#34;。

轻松避免这种情况

关于index.js:

Alloy.Globals.indexController = $;

在etape_1_form.js

outerView: Alloy.Globals.indexController.home