JSONSerialization.WritingOptions
介绍 WritingOptions
下面的枚举有 4 个 option,但是有一个是 13beta 版本的,文档也写了 unavilible,所以我们直接跳过,就看可以使用的是 3 个,分别是:
prettyPrinted JSON 美化格式带换行,空格等
sortedKeys 对 JSON 的 Object 对象的 Key 进行排序
fragmentsAllowed 允许所有的 JSON 对象类型作为 JSON 的根类型
分别是什么意思
@available(iOS 5.0, *)
public struct WritingOptions : OptionSet {
public init(rawValue: UInt)
public static var prettyPrinted: JSONSerialization.WritingOptions { get }
/* Sorts dictionary keys for output using [NSLocale systemLocale]. Keys are compared using NSNumericSearch. The specific sorting method used is subject to change.
*/
@available(iOS 11.0, *)
public static var sortedKeys: JSONSerialization.WritingOptions { get }
public static var fragmentsAllowed: JSONSerialization.WritingOptions { get }
@available(iOS 13.0, *)
public static var withoutEscapingSlashes: JSONSerialization.WritingOptions { get }
}验证
零,none
一,prettyPrinted
二,sortedKeys
可以看到 排序是递归的,这个 JSON 所有的 Object 的 Key 都被排序了。 不管是外层还是内层。
三,fragmentsAllowed
允许所有 JSON 所有的类型,作为 JSON 的最外层。 比如,一个 Number,String,Bool,Null 都可以作为一个 JSON,没有带上这个 option,默认只允许,Object 和 Arrary 这两种类型作 JSON 的最外层。
最后更新于
这有帮助吗?