我有一个工作流程的主干设置。在任何给定时间,页面上都可以看到多个工作流/模型。如果工作流尚未启动(即不在数据库中),它将显示为新模型。将获取的模型传递给视图时遇到问题。我只是传递属性而不是它看起来的集合?有人有想法么?
当我从数据库中获取所有工作流时,它会返回一个工作流进度的 JSON 数组。
[{
"ref_id": 41959,
"parent_ref_id": 35,
"fk_workflow_id": 2,
"stage": 1,
"status_max": 4,
"updated": "2012-05-14 17:30:46"
}, {
"ref_id": 41960,
"parent_ref_id": 35,
"fk_workflow_id": 3,
"stage": 3,
"status_max": 4,
"updated": "2012-05-14 12:30:48"
}]
加载页面时,所有工作流都被创建为“新模型”,因为我们不知道它们是否已经启动。一旦 fetch 返回了已启动的模型,我必须将适当的模型传递给视图。我无法弄清楚如何正确传递模型(即我可以传递属性,但似乎在那之后,我无法访问 collection.create 函数等?)
var self = this;
this.workflows = new Workflow.WorkflowCollection();
this.workflows.fetch({
data:{
ref_id: REF_ID
},
success: function(model, response) {
for(var i = 0, ln = model.models.length; i< ln;i++) {
self.switchWorkflow(model.models[i].get("fk_workflow_id"), new Workflow(model.models[i].attributes));
}
}
});
这是我可以确定主干知道需要设置多少个模型的唯一方法(没有为每个客户启动每个工作流程 - 大约 100 万行)
setupWorkflowSpaces: function(model) {
for(var i =0; i<Workflow.FileWorkflows.length;i++) {
this.switchWorkflow(Workflow.FileWorkflows[i], false);
}
},
switchWorkflow: function(workflow_id, model) {
if(!model)
model = new Workflow;
switch(workflow_id) {
case 1:
this.applicationProcessView(model);
break;
case 2:
this.kitView(model);
break;
case 3:
this.posView(model);
break;
default:
alert('wut');
break;
}
},
kitView: function(model) {
console.log(model);
model.set("fk_workflow_id", 2);
if(this.kit) this.kit.close();
this.kit = new Workflow.PostageView({
model: model
});
},