- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在处理实体和模型。基本上我的实体描述了我的数据应该是什么样子,我的模型扩展了这些实体并有一个函数 toMap 将它们转换成一个 json 对象。
所以我有 2 个实体,Car 和 Brand,其中一个 Car 属性是 Brand 类型。
class Car {
final String name;
final Brand brand;
const Car({
required this.name,
required this.brand,
});
}
class Brand {
final String label;
final String color;
const Brand({
required this.label,
required this.color,
});
}
然后我有 2 个模型 CarModel 和 BrandModel,分别扩展了 Car 和 Brand。
class CarModel extends Car {
CarModel({
required String name,
required BrandModel brand,
}) : super(
name: name,
brand: brand,
);
Map<String, dynamic> toMap() {
return {
'name': name,
'brand': brand,
};
}
}
class BrandModel extends Brand {
BrandModel({
required String label,
required String color,
}) : super(
label: label,
color: color,
);
Map<String, dynamic> toMap() {
return {
'label': label,
'color': color,
};
}
}
如您所见,在 CarModel
中,我希望 brand
属性的类型为 BrandModel
。但是,它采用其父类(super class)类型。
最后,我的 CarModel
中的 brand
属性的类型为 Brand
。
我的问题是在 toMap 函数中,我想像这样使用 brand.toMap:
Map<String, dynamic> toMap() {
return {
'name': name,
'brand': brand.toMap(), // <= I want to use toMap() here, so I need brand to be of type BrandModel
};
}
有没有办法强制我的子类为从父类(super class)继承的属性设置不同的类型?
最佳答案
有趣的问题。您正在尝试实现继承。那么,当您提供 required BrandModel brand,
时会发生什么?在 CarModel
的构造函数中延伸Car
有final Brand brand;
字段类型。 Brand
从 BrandModel
获取必要的属性/定义对象,这是您无法调用 'brand': brand.toMap(),
的唯一原因在Map<String, dynamic> toMap()
里面方法基础 Brand
类没有这个方法。
子项具有父项的所有属性/功能/定义,但父项不具备子项的所有属性。
解决方案
所以,你需要把toMap()
在Brand
类(class)。 Abstraction 出现了。在这个阶段,可能是 toMap()
method 不清楚你喜欢它在体内有什么,它会映射什么?简单地说,将其声明为 abstract
.另外,将该类声明为抽象类。 抽象类应该有抽象方法。
现在,多态性 出现了。在BrandModel
中类,toMap()
方法将是一个覆盖方法。检查以下测试代码(完整示例)。
class Car {
final String name;
final Brand brand;
const Car({
required this.name,
required this.brand,
});
}
abstract class Brand {
final String label;
final String color;
const Brand({
required this.label,
required this.color,
});
Map<String, dynamic> toMap();
}
class CarModel extends Car {
CarModel({
required String name,
required BrandModel brand,
}) : super(
name: name,
brand: brand,
);
Map<String, dynamic> toMap() {
return {
'name': name,
'brand': brand.toMap(),
};
}
}
class BrandModel extends Brand {
BrandModel({
required String label,
required String color,
}) : super(
label: label,
color: color,
);
@override
Map<String, dynamic> toMap() {
return {
'label': label,
'color': color,
};
}
}
void main() {
BrandModel brand = BrandModel(label:'Test',color : 'white');
CarModel car = CarModel(name: 'T',brand : brand);
print(car.toMap());
}
关于flutter - 如何为子类属性提供与 Dart 中的父类(super class)不同的类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69376728/
我是一名优秀的程序员,十分优秀!