写在前头:本插件只适用 android studio和 Intellij IDEA 工具,eclipse 的少年无视我吧!!!
这是一个根据JSONObject格式的字符串,自动生成实体类参数.
1.2.0 版本更新内容:
新增处女座模式 →_→
- 修复List 泛型错误的问题;
- 支持 自定义 Filed Name 前缀
- 支持除Gson数据转换库 (eg: Jackson, FastJson)
版本1.1.3
1.1.3 版本更新内容:
- 内部类使用 static 修饰;
- 生成属性的时候会过滤父类的属性;
- 支持修改实体类的后缀名,保持跟项目命名规则的统一;
- 支持自动生成转换方法;
- 支持转换方法的修改;
- 支持是否复用内部实体类,默认不启用;
- 支持转换异常的异常信息查看;
版本1.1.2
1.1.2 版本更新内容:
- 修复了开启对话框会闪一下的 bug;
- 增加了设置界面;
- 增加了使用Public 修饰成员变量,替代 private 和 set/get 方法.默认为 private ,可以手动切换过来;
- 支持全部变量用注解(SerializedName)的形式.然后你就可以混淆实体类.
版本1.1.1
1.1.1版本更新内容
- 修复了因为过滤//注释代码导致的出现的 Json 格式验证异常;
- 支持解析 java 的关键字作为 key (支持字段:
default,abstract,null,final,void,implements,
this,instanceof,native,new,goto,const,volatile,return,finally)其余暂不支持;
版本1.1.0
1.1.0 版本更新内容:
- 支持数组中嵌套数组的解析;
- 支持过滤Json格式中的注释代码.
Usage
安装方法1:
1.Android studio File->Settings..->Plugins-->Browse repositores..搜索Gson 2.安装插件,重启android studio
安装方法2:
1.下载GsonFormat.jar ; 2.Android studio File->Settings..->Plugins --> install plugin from disk..导入下载的GsonFormat.jar 3重启android studio
使用方式
在实体类中使用Generate的快捷键.
快捷键:图中选中的部分
我这边的快捷键是 command+n;
1.2.0 截图
简单的实体类:
图中简单的 json 格式
{
"name": "王五", "gender": "man", "age": 15, "height": "140cm", }
图中的实体类
**
* Created by 轻微 on 15/1/9. */ public class Bean { /** * height : 140cm * age : 15 * name : 王五 * gender : man */ private String height; private int age; private String name; private String gender; public void setHeight(String height) { this.height = height; } public void setAge(int age) { this.age = age; } public void setName(String name) { this.name = name; } public void setGender(String gender) { this.gender = gender; } public String getHeight() { return height; } public int getAge() { return age; } public String getName() { return name; } public String getGender() { return gender; } }
复杂的实体类:
实体类不仅包含另外一个实体,还包含另外实体的数组.
图中复杂的json 格式
{
"name": "王五", "gender": "man", "age": 15, "height": "140cm", "addr": { "province": "fujian", "city": "quanzhou", "code": "300000" }, "hobby": [ { "name": "billiards", "code": "1" }, { "name": "computerGame", "code": "2" } ] }
图中的实体类
/** * Created by 轻微 on 15/1/9. */ public class Bean extends JSONModel { /** * height : 140cm * age : 15 * name : 王五 * hobby : [{"name":"billiards","code":"1"},{"name":"computerGame","code":"2"}] * gender : man * addr : {"province":"fujian","code":"300000","city":"quanzhou"} */ private String height; private int age; private String name; private List<HobbyEntity> hobby; private String gender; private AddrEntity addr; public void setHeight(String height) { this.height = height; } public void setAge(int age) { this.age = age; } public void setName(String name) { this.name = name; } public void setHobby(List<HobbyEntity> hobby) { this.hobby = hobby; } public void setGender(String gender) { this.gender = gender; } public void setAddr(AddrEntity addr) { this.addr = addr; } public String getHeight() { return height; } public int getAge() { return age; } public String getName() { return name; } public List<HobbyEntity> getHobby() { return hobby; } public String getGender() { return gender; } public AddrEntity getAddr() { return addr; } public class HobbyEntity { /** * name : billiards * code : 1 */ private String name; private String code; public void setName(String name) { this.name = name; } public void setCode(String code) { this.code = code; } public String getName() { return name; } public String getCode() { return code; } } public class AddrEntity { /** * province : fujian * code : 300000 * city : quanzhou */ private String province; private String code; private String city; public void setProvince(String province) { this.province = province; } public void setCode(String code) { this.code = code; } public void setCity(String city) { this.city = city; } public String getProvince() { return province; } public String getCode() { return code; } public String getCity() { return city; } } }
1.1.1的过滤注释功能讲解:
支持 java 两种注释过滤:
/**段注释: */ //行注释:
例子:
{
/** * 名字 */ "name": "王五", "gender": "man",//性别 "age": 15, "height": "140cm", }
这样它也是可以解析的.