kotlin的数据类,由于其内部封装了getter和setter方法,极大地简化了我们的编程代码,但同时其不能像java那样方便的重写getter或者setter方法,也给大家造成了一定的麻烦。
举个例子:
data class OrderBean(val createTime: Long)
后端返回的订单数据中,createTime
这个字段是长整型的时间戳,但是前端需要转成yyyy-MM-dd
这种格式,或者yyyy年MM月dd日
这种,再或者更加友好一点,根据时间段,转成1小时前
、2天前
、一周前
这种,在实际开发中都是常有的情况,在Java
中我们可以很方便的在getter方法中做这些处理,但是kotlin
的getter方法都是内部封装的,并不直接支持重写,我看到网上有些答案是像这样处理的:
data class OrderBean(val _createTime: Long){
val createTime:String
get() = { ...do something }
}
这样处理其实并没有真正改变createTime
的值,反而会造成一些更大的麻烦,比如,数据类中自动生成的equals()
,toString()
等一些方法还是会沿用长整型的值,而且当你做某些值对比的时候,会产生一些不可预测的结果。
正确的姿势
有以下三种,你可以根据自己的业务逻辑和团队的话语权进行选择:
让后端改:如果有可能的话,这是最合理,最恰当的方式,后端直接返回我们需要的字段形式,节省了移动端,web端,小程序端等每端各写一套逻辑的时间,并且万一哪段比较坑,实现出来的时间跟你们不一样,可能你们每个都要复查一遍。另外,后端写的话,一旦需求变更,后端处理起来要更加简单方便。
不用
data class
,使用常规的class
:不要拘泥于建议,谁说这些数据实体类就必须要用data class
的,使用IDE去自动生成,照样可以,而且还实现了自己的完全控制。另外创建一个安全的变量:如果在团队中实在人微言轻,有非要用
data class
,那就去另外创建一个变量,比如:
data class OrderBean(val createTime: Long){
val createTimeShow:String
get() = { ...do something }
}