Nutz.Json 转为Json字符串

优质
小牛编辑
133浏览
2023-12-01

输出目标

  • 字符串
  • Writer
  • File

格式控制

  • JsonFormat,即运行时配置
  • 注解配置,永久的, 请看"Json注解"一节

输出目标

如果对象不大,直接转json字符串是最方便的咯

Json.toJson(pet);

输出到Writer,适合大对象,不然耗太多内存了

Json.toJson(writer, pet);

直接输出到文件去

Json.toJsonFile(file, pet);

JsonFormat格式控制

Json.toJson系列方法,除了输出目标,就是JsonFormat了, 但注意一下,JsonFormat不会影响Json注解中的配置哦

JsonFormat提供了几种快捷配置(静态方法,但可以继续链式设置)

Json.toJson(pet, JsonFormat.compact()); // 紧凑模式 -- 无换行,忽略null值
Json.toJson(pet, JsonFormat.full());    // 全部输出模式 -- 换行,不忽略null值
Json.toJson(pet, JsonFormat.nice());    // 一般模式 -- 换行,但忽略null值
Json.toJson(pet, JsonFormat.forLook()); // 为了打印出来容易看,把名字去掉引号
Json.toJson(pet, JsonFormat.tidy());    // 不换行,不忽略空值

JsonFormat详解

下面,将一一讲解JsonFormat中的配置项. 各种配置均可链式设置,以达到叠加效果.

indentBy -- 缩进所使用的字符,默认是3个空格

Json.toJson(pet, JsonFormat.full().setIndentBy("t"));// 输出的缩进将使用tab

compact -- 是否为紧凑模式,默认为false. 若为true,indent和indentBy将无效.

Json.toJson(pet, JsonFormat.full().setCompact(true)); // 不作任何换行和缩进

quoteName -- key是否用双引号包起来,默认为true,同时也是json标准格式的要求. 若设置为false,则新版的jquery将解析出错.

Json.toJson(pet, JsonFormat.full().setQuoteName(false)); // 输出类似 {name:"wendal"}

ignoreNull -- 控制是否忽略null值,默认为false

Json.toJson(pet, JsonFormat.full().setIgnoreNull(true)); // null值的key-value将不会输出,但空List还是会的.

actived -- 仅输出哪些的key,默认为null,即允许所有key. 注意,这是正则表达式!

Json.toJson(pet, JsonFormat.full().setActived("^(name|id|location)$"); // 仅输出name/id/location,其他key都不输出

locked -- 与actived刚好相反, 不输出哪些的key,默认为null,即允许所有key. 注意,这是正则表达式!

Json.toJson(pet, JsonFormat.full().setLocked("^(location)$"); // 不输出location,其他key正常输出

separator -- 分隔符,不可配置,路过吧

autoUnicode -- 自动转换为unicode,默认为false. 特殊需要,一般用不上

Json.toJson(pet, JsonFormat.full().setAutoUnicode(true); // 当非英文字符出现时,转为uf003 形式 

unicodeLower -- Unicode编码是大写还是小写,默认大写

dateFormat -- 日期格式

Json.toJson(pet, JsonFormat.full().setDateFormat("yyyyMMdd"); // 将输出类似于 {"b":"20190823"}

castors -- 高级货,基本上不会用到.

indent -- 临时变量.