gpt4 book ai didi

backbone.js - Typescript 类型检查 - Backbone.Model 实例无法进行类型检查

转载 作者:搜寻专家 更新时间:2023-10-30 21:13:15 25 4
gpt4 key购买 nike

我在使用 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();

});

内部渲染():

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});
}
....
}

Except instanceof 永远不会评估为真,因为似乎从 Backbone.Model 派生的“类类型”被分配给 Backbone.Model.attributes 而不是类本身的实例。我相信这是因为在实现派生自 Backbone.Model 的类时,我遵循了 this方法,看起来这可能是这个问题的原因。基本上它将 TS 类上的 get/set 属性委托(delegate)给底层的 Backbone.model.get()/set(),后者又设置 attributes 属性的值。

看来我要么放弃这种方法(并希望这是问题所在),要么想出一种方法来执行松散耦合的类型检查,类似于或使用 baseChartModel 之间的 instanceof .attributes 对象和我的 App.BackBone.Models.ScatterPlotModel

类原型(prototype)

这个断点在与instanceof比较的那一行 enter image description here

有什么想法吗?

最佳答案

您使用的方法似乎足够有效。我已将以下代码插入 TypeScript Playground ,只是为了检查一些 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],因此实例失败了?

希望对您有所帮助,

关于backbone.js - Typescript 类型检查 - Backbone.Model 实例无法进行类型检查,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15728582/

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