iOS SmartCodable 替换 HandyJSON 适配记录

前言

HandyJSON群里说建议不要再使用HandyJSON,我最终选择了SmartCodable 来替换,原因如下:

首先按照 SmartCodable 官方教程替换

大概要替换的内容如图:

详细的替换教程请前往:使用SmartCodable 平替 HandyJSON

忽略key的解析

在 SmartCodable 中可以使用 @IgnoredKey很方便的忽略解析 某个 Key

使用场景:

在 model 中 加入了一个默认不支持解析的字段,也不需要解析的时候,就需要加@IgnoredKey 来标识忽略解析
示例

swift 复制代码
class GetDailyPlansListModel: SmartCodable{
required init() { }
var should_study_time: String = ""
var dayCompareType = StudyDayCompare.today
}

编译报错
Cannot automatically synthesize 'Encodable' because 'StudyDayCompare' does not conform to 'Encodable'
修改

swift 复制代码
class GetDailyPlansListModel: SmartCodable{
required init() { }
var should_study_time: String = ""
@IgnoredKey
var dayCompareType = StudyDayCompare.today
}

项目中同时使用了WCDB 解决冲突

如果这个 model 同时要用来解析 json 和 存数据库,那么
注意了: 解析只会解析 CodingKeys 里面定义的字段
最简单的适配 :自然是将你要解析的字段在 CodingKeys 中补全
还有一个思路:将数据解析和数据缓存分别用一个 model ,这个项目逻辑复杂的话,会非常麻烦,但如果不想存多余的字段,也只有这样了

swift 复制代码
class GiftGoodsModel: SmartCodable,TableCodable {
    required init() {}
    
    var id:Int = 0 // 礼包商品id
    var ios_goods_id:String = "" // ios商品id "com.yuanlue.cxs.baijuyi",
    var name: String = "" //"庭院诗人-白居易",
    var price:Int = 0 //商品价格
    var source_price:Int = 0 //商品原价
    var pic:String = "" //商品图片
    var recommend:Bool = false //是否推荐
    
    //MARK: ==凑单
    var good_id:Int = 0 //商品id
    //MARK: ==购物车
    var count:Int = 0 //商品数量
    
    var gift_pack_id:Int? //礼包id(字段可空,有值是礼包,无值是普通商品)
    
    enum CodingKeys: String, CodingTableKey {
        typealias Root = GiftGoodsModel
        static let objectRelationalMapping = TableBinding(CodingKeys.self)
        case id
        case ios_goods_id
        case name
        case price
        case source_price
        case pic
        case recommend
        case good_id
        case count
        case gift_pack_id
    }
}

遇到解析 model 就会稍微麻烦点,要在CodingKeys 中将这个model key 加入,WCDB 不支持这种类型,就要去自定义字段映射。

详细教程前往 WCDB 官方文档查看:Swift 自定义字段映射类型

总结

以上便是我使用SmartCodable 替换 HandyJSON中遇到的值得记录的地方。改动 460个地方,替换时间 1.5 天,就是数据库冲突的解决比较耗时,如果没有跟我一样使用 WCDB 的话,替换应该挺轻松地。


感谢您的阅读和参与,HH思无邪愿与您一起在技术的道路上不断探索。如果您喜欢这篇文章,不妨留下您宝贵的赞!如果您对文章有任何疑问或建议,欢迎在评论区留言,我会第一时间处理,您的支持是我前行的动力,愿我们都能成为更好的自己!

相关推荐
2501_940094027 小时前
iPhone Delta模拟器游戏资源包合集中文游戏ROM+BIOS+Delta皮肤附游戏导入教程
游戏·ios·iphone
2501_915918417 小时前
HTTP和HTTPS工作原理、安全漏洞及防护措施全面解析
android·http·ios·小程序·https·uni-app·iphone
白玉cfc7 小时前
【iOS】UICollectionView
macos·ios·cocoa
2501_916007479 小时前
如何在 Windows 电脑上调试 iOS 设备上的 Safari?完整方案与实战经验分享
android·windows·ios·小程序·uni-app·iphone·safari
2501_915918419 小时前
uni-app iOS日志管理实战,从调试控制台到系统日志的全链路采集与分析指南
android·ios·小程序·https·uni-app·iphone·webview
ajassi20009 小时前
开源 Objective-C IOS 应用开发(一)macOS 的使用
macos·ios
ajassi20009 小时前
开源 Objective-C IOS 应用开发(二)Xcode安装
ios·objective-c·xcode
YungFan10 小时前
SwiftUI-WebView 全面指南
ios·swiftui
猪哥帅过吴彦祖10 小时前
Flutter 从入门到精通:深入 Navigator 2.0 - GoRouter 路由完全指南
android·flutter·ios
Kapaseker12 小时前
Kotlin 跨平台开发中的权衡
android·ios·kotlin