我遇到了Typescript和Backbone集合的问题。这是一些基础:
class BaseChartModel extends Backbone.Model { }
class ScatterPlotModel extends BaseChartModel { }
class BarChartModel extends BaseChartModel { }
class MixedChartCollection extends Backbone.Collection { public model: BaseChartModel; ... }
class ScatterPlotCollection extends Backbone.Collection { public model: ScatterPlotModel; ... }
class BarChartCollection extends Backbone.Collection { public model: BarChartModel; ... }
然后我执行以下操作:
var scatterPlotCollection = new ScatterPlotCollection();
var scatterPlotCollectionXhr = scatterPlotCollection.fetch({...});
var barChartCollection = new BarChartCollection();
var barChartCollectionXhr = barChartCollection.fetch({...});
$.when(scatterPlotCollectionXhr, barChartCollectionXhr).done(() => {
mixedCollection = new MixedChartCollection();
mixedCollection.add(scatterPlotCollection.models, { silent: true });
mixedCollection.add(barChartCollection.models, { silent: true });
chartViewList = new MixedChartViewList({ collection: mixedCollection });
chartViewList.render();
});
在render()中:
public render(){
var self = this;
this.$el.html(this.template({}));
this.collection.forEach(
(chartModel: BaseChartModel) => {
this.$el.append(self.AddChartView(chartModel).render());
}
);
return this;
}
public AddChartView(baseChartModel: BaseChartModel) : BaseChartView {
var newChartView: BaseChartView;
if(baseChartModel instanceof ScatterPlotModel){
newChartView = new ScatterPlotView({ model: baseChartModel});
} else if (baseChartModel instanceof BarChartModel){
newChartView = new BarChartView({ model: baseChartModel});
}
....
}
除了instanceof
永远不会计算为true,因为似乎从Backbone.Model
派生的'类类型'被赋值给Backbone.Model.attributes
而不是类本身的实例。我相信这是因为在实现从Backbone.Model派生的类时,我遵循this方法,看起来这可能就是这个问题的原因。基本上它将TS类的get / set属性委托给底层的Backbone.model.get()/ set(),后者又设置attributes
属性的值。
似乎我必须放弃这种方法(并希望这是问题)或找出一种方法来进行松散耦合类型检查,类似于instanceof
对象之间或使用baseChartModel.attributes
我的App.BackBone.Models.ScatterPlotModel
此断点位于instanceof
比较的行
有什么想法吗?
答案 0 :(得分:1)
您使用的方法似乎足够有效。我已将以下代码插入到TypeScript游戏中,只是为了检查一些javascript语法:
class A { }
class B extends A { }
class Checker {
static isA(input: A) {
return (input instanceof A);
}
}
var a = new A();
var b = new B();
document.writeln('a instanceof A ' + (a instanceof A) + '<br/>');
document.writeln('b instanceof B ' + (b instanceof B) + '<br/>');
document.writeln('b instanceof A ' + (b instanceof A) + '<br/>');
document.writeln('b instanceof A (via function) ' + Checker.isA(b) + '<br/>');
var aArray : A[] = [];
aArray.push(a);
aArray.push(b);
for(var i = 0; i < aArray.length; i++) {
document.writeln('aArray[' + i + '] instance of A ' + (aArray[i] instanceof A) + '<br/>' );
}
这给出了以下输出:
a instanceof A true
b instanceof B true
b instanceof A true
b instanceof A checker true
aArray[0] instance of A true
aArray[1] instance of A true
这必须意味着通话
mixedCollection.add( scatterPlotCollection.models, { silent: true });
这里引起了问题 可能scatterPlotCollection.models没有返回原始对象(即ScatterPlotModel或BarChartModel),而只是返回[Object object],因此实例失败了?
希望这有帮助,
答案 1 :(得分:0)
我想我知道'bug'在哪里:某种程度上宣告
public model: CustomModelType
不起作用;
但是,如果您要创建这样的集合:
new MyCustomCollection(null, { model: CustomModelType });
然后骨干将能够按预期创建模型。
为什么会发生,我不知道:( 可能是类型定义中的错误。