最近遇到个小问题,不是什么技术难点,但也是种思路嘛!分享出来给大家看看。
相信大家都做过复杂类型的列表页,一般APP的首页都是这样的。
服务器返回的是json数据,我们可以通过Fastjson或Gson直接将json字符串转换为对应的java bean即可,java由于是强类型的,所以必须实现定义好类型,我们来看个例子:
假如服务器返回的数据是这样的:
[
{
“type" = 1
"a" ={...}
"b" =null
"c" =null
}
{
“type" = 2
"b" ={...}
"a" =null
"c" =null
}
{
“type" = 3
"c" ={...}
"a" =null
"b" =null
}
...
]
当然实际开发时数据要复杂得多。我们对应的首页的bean可以定义三个字段type、a、b,json数据转换为对象时,类型相对的字段就会被赋上值,列表时也可以根据类型来填充。
如果服务器返回的数据是这样呢?
[
{
"type" = 1
"data" ={...}
}
{
"type" = 3
"data" ={...}
}
{
"type" = 2
"data" ={...}
}
...
]
这种情况就尴尬了,不同类型对应不同的bean,java的列表是只允许存放相同类型数据的,既然我们无法在json转换为对象时确定data的具体类型,那么可以这样定义bean:
class Test{
var type:Int = 0
var data:JsonObject? = null
//再定义实际类型的字段
var a:A?=null
get(){
val gson = Gson()
val jsonElement = jo!!.get("data").asJsonArray
return gson.fromJson(gson.toJson(jsonElement), object : TypeToken<A>>() {}.type)
}
var b:B?=null
get(){
val gson = Gson()
val jsonElement = jo!!.get("data").asJsonArray
return gson.fromJson(gson.toJson(jsonElement), object : TypeToken<B>>() {}.type)
}
...
}
然后你就可以拿着list:List<Test>愉快的填充列表了,只要你在渲染type=1时乖乖去拿对应的a字段就ok了,其他类似,当然如果有列表的也是同理。
retrofit添加Gson转换器直接将json转换为对象了,所以会有这种问题,当然你也可以直接根据key来操作返回的json串,方法有很多,你可以选择你喜欢的方式。
当然如果你可以让服务器哥们修改返回的数据结构也是可以的,前提是你要和IOS组的哥们串通好,不然容易被怼。如果你要更好的方式也欢迎和我交流。
欢迎关注我的公众号:子质