gpt4 book ai didi

javascript - NativeScript UI 构建器

转载 作者:行者123 更新时间:2023-11-29 21:17:09 24 4
gpt4 key购买 nike

我尝试构建一个简单的类似表单的 UI,我想在其中动态添加多个 TextField 的行。我用 XML 和 JS 构建了一个自定义组件,因为在这些 TextFields(开始、结束、持续时间)中有一些交互。

我是 NativeScript 的初学者,但我的数据绑定(bind)和事件结构正在运行。我能够通过 ui/builder 添加我的自定义组件。我完全卡住的地方是为这个组件实例获取“选项/参数”。我试图完成的是:添加我的自定义组件并为其提供一些数据,这些数据应该填充到组件 Obsverable 中。在稍后的(保存)操作中,我希望能够从我的“主” View 中检索这些数据。

我的结构是这样的:

主要.js

exports.loaded = function(args) {
var page = args.object;
page.bindingContext = model;

var outerContainer = page.getViewById('outerContainer');

var vma = builder.load({
path: 'widgets/durationRow',
name: 'durationRow'
});

outerContainer.addChild(vma);
};

自定义组件“durationRow.js”

var componentModel = new Observable({
label: "",
start: "",
end: "",
duration: ""
});

exports.onLoad = function(args){
var container = args.object;
container.bindContext = componentModel;
};

我尝试通过 exports.componentModel 导出 componentModel 并从 main 中寻址 vma.componentModel。但是 vma 是一个 View ,而不是“JS 模块”。我真的被卡住了,没有找到任何像我的场景那样做的例子。

谁能给我指出正确的方向,我如何才能以正确的(或任何)方式做这些事情?

谢谢!

最佳答案

所以这个问题的答案很简单:阅读 documentation :)

有一个选项attributes可以完全用于此。我最终得到了这个:

var row = builder.load({
path: 'widgets/durationRow',
name: 'durationRow',
attributes: {
bindingContext: bindingModel
}
});
container.addChild( row );

在加载的小部件中,我将“插入”模型作为 bindingContext:

exports.onLoad = function(args){
page = args.object;
var model = page.bindingContext;
};

希望对您有所帮助!

关于javascript - NativeScript UI 构建器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38991268/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com