从Net3开始支持使用kotlin-serialization(简称KS). 我愿称他为最强序列化库
Net完美支持kotlin-serialization创建转换器
注意Ks的数据模型类都要求使用注解
@Serializable
.
一般开发中都是使用插件生成数据模型, 所以这并不会增加工作量. 即使手写也只是一个注解, 但是可以带来默认值支持和更安全的数据解析
这里使用Demo中的SerializationConvert作演示. 如果你业务有特殊需要可以复制Demo中的转换器代码稍加修改
=== "全局配置"
```kotlin
NetConfig.init("http://google.com/") {
setConverter(SerializationConvert())
// ... 其他配置
}
```
=== "单例配置"
```kotlin
val userList = Get<List<UserModel>>("list-data") {
converter = SerializationConvert() // 单例转换器, 此时会忽略全局转换器
}.await()
```
scopeNetLife {
val userList = Get<List<UserModel>>("list-data") {
// 该转换器直接解析JSON中的data字段, 而非返回的整个JSON字符串
converter = SerializationConvert() // 单例转换器, 此时会忽略全局转换器
}.await()
tvFragment.text = userList[0].name
}
@Serializable
data class UserModel(var name: String, var age: Int, var height: Int)
具体解析返回的JSON中的某个字段请在转换器里面自定
如果想详细了解KS, 请阅读文章: Kotlin最强解析库 - kotlin-serialization