我似乎无法理解我在客户端应用程序上遇到的错误。我正在订阅graphql订阅,我能够检索更新,但我无法将更改推送到名为" models:ModelClass []"的typescript数组。这是绑定到视图。
我有什么遗漏或做错了吗?
models.component.ts
this.apollo.subscribe({
query: gql`
subscription {
newModelCreated{
_id
name
type
train_status
deploy_status
data_path
description
created_at
updated_at
}
}
`
}).subscribe((data) => {
console.log("CREATED: " + JSON.stringify(data.newModelCreated));
console.log(data.newModelCreated);
var temp:ModelClass = data.newModelCreated;
this.models.push(temp);
});
模型class.ts
export interface ModelClass {
_id: string;
name: string;
type: string;
parameters: {
alpha: number;
};
train_status: string;
deploy_status: string;
test_accuracy: string;
created_at: number;
updated_at: number;
}
答案 0 :(得分:1)
我认为this.models是Apollo返回的数组,你想在你的初始数组中添加新创建的对象吗?如果为true,Apollo将返回一个不可变的对象!
您必须克隆初始返回的数组。类似于订阅功能的东西:
this.apollo
.watchQuery({query: INITIAL_GQL_REQUEST})
.subscribe((data) => {
this.models = data.models.map((model) => {
return {
id: model.id,
name: model.name,
another: model.another
}
})
};
});
然后您的订阅请求将能够将创建的模型添加到此普通javascript数组。
PS:不确定,但我认为Apollo会返回不可变对象,因为它们存储在商店中,并且根据您的提取策略,如果您能够改变它们,它可能会错过商店命中。
希望有所帮助