Python 官方文档:入门教程 => 点击学习
目录1、假设我们要创建一个JSON对象格式如下:2、往常创建jsON语法:3、解决方案——链式创建JSON:4、实现多级JSON5、YtJSONObject类
我们主要介绍一下:java中如何通过最简单的方式实现链式创建json对象,解决创建json代码臃肿的问题。
{
"code": 0,
"msg": "SUCCESS"
}
java中传统的创建json一般采用如下形式,先来看一个例子:
JSONObject res = new JSONObject();
res.put("code",0);
res.put("msg","SUCCESS");
这个例子中,每往json中加入一个元素都需要写一遍res.put,每行只能创建一个json的数据,这样比较繁琐,代码也很臃肿,是不是觉得很不科学。
如果你觉得这还能接受,那么你不妨试试二级json,三级json,完整的写下来,你的代码能有几十行是毫不夸张的。
我们可以采用链式创建JSON的方法,例如下面例子:
JSONObject res1 = new YtJSONObject().put("code",0).put("msg","SUCCESS").getHome();
通过以上例子中,我们实现了链式创建JSON,每往JSON中加入一个元素,只需要在链式写法(也称链条语法)中写.put接上新元素即可。
这样我们就实现了链式创建JSON,好处是免去每次都写res.put的烦恼,创建一个完整的JSON对象只需要一行代码即可,这样代码就整洁清晰了很多。
以上例子中我们用到了一个类:YtJSONObject,这个类是将JSONObject类再次封装的一个加强类,通过.put元素链条写完后,最终采用.getHome获取得到JSONObject类对象,从而实现JSON的链式写法。
如需获取JSON字符串,我们只需要使用JSONObject对象原有的方法,例如:
String str = new YtJSONObject().put("code",0).put("msg","SUCCESS").getHome().toString();
这里的.getHome()方法就是真正获取到了JSONObject类对象,同时也就支持了JSONObject类对象的一切方法,所以可以调用.toString()转为json字符串。
很多时候我们的json都不是一级的,还会有二级、三级、无数级,此时使用传统的json声明语法只会时代码越来越多,作用却不大。
使用链式json如何实现呢,我们来看个例子:
JSONObject res2 = new YtJSONObject()
.put("code",0)
.put("msg","SUCCESS")
.put("result",
new YtJSONObject()
.put("id",1)
.put("url","a")
)
.getHome();
以上例子中我们实现了一个二级JSON,就是增加了一个result级别的json,直接在赋值的地方继续new YtJSONObject对象,然后继续向下使用链式写法即可,如果你还需要三级JSON甚至多级JSON也是同理。
为了让语法看起来更加清晰,我把链式写法格式化了一下,更容易看清楚,实际应用中不太长的JSON链式写法完全可以写在一行上。
import com.alibaba.fastjson.JSONObject;
public class YtJSONObject {
private JSONObject home;
public YtJSONObject() {
this.home = new JSONObject();
}
public YtJSONObject put(String key, Object value) {
home.put(key, value);
return this;
}
public JSONObject getHome() {
return home;
}
}
该类只是增强了JSONObject类,使JSONObject类支持链式语法,并不是自行创建了一种JSON类类型,因此使用时还需要在pom.xml中引入一下fastjson
到此这篇关于java链式创建json对象的文章就介绍到这了,更多相关java链式创建json对象内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: java链式创建json对象的实现
本文链接: https://www.lsjlt.com/news/138851.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0