- 在 Podfile 中添加
pod 'CCUserDefaultsManager'
。如果安装失败,请更新本地pod库pod repo update
。 - 执行 pod install 或 pod update。
- 导入
CCUserDefaultsManager.h
这是一个用来集中式管理NSUserDefaults
存储的框架,使对NSUserDefaults
的存取操作具有更高的内聚性,框架原理是利用了Objective-C的runtime特性,动态修改了类的property行为。当使用[[CCUserDefaultsManager sharedManager] addClass:XXClass]
方法,那么XXClass
的所有成员变量的get
和set
都会映射成NSUserDefaults对应的存取方法.
支持的存储类型:
- c语言类型,仅支持整形、浮点型、布尔型,包括NSInteger,CGFloat等
- oc对象类型,仅支持NSString, NSData, NSNumber, NSDate, NSArray, NSDictionary ,NSURL等不可变版本
/// .h文件
@interface CCUserDefault : NSObject
/// 使用单例
@property (class, readonly, strong) CCUserDefault *sharedManager;
/// c语言类型,仅支持整形、浮点型、布尔型,包括NSInteger,CGFloat等
@property (nonatomic, assign) int intType;
/// oc对象类型,仅支持NSString, NSData, NSNumber, NSDate, NSArray, NSDictionary ,NSURL等不可变版本
@property (nonatomic, strong) NSString *string;
/// 忽略的成员变量,需要实现CCUserDefaultsManager协议
@property (nonatomic, strong) NSString *ignoreString;
@end
/// .m文件
#import "CCUserDefaultsManager.h"
@implementation CCUserDefault
+ (CCUserDefault *)sharedManager
{
static CCUserDefault *_mgr = nil;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
_mgr = [CCUserDefault new];
});
return _mgr;
}
+ (void)load
{
/// 将CCUserDefault添加到CCUserDefaultsManager中,那么CCUserDefault的成员变量的`set`和`get`方法都会映射成与`NSUserDefaults`对应的存取方法
[[CCUserDefaultsManager sharedManager] addClass:self];
}
@end
存值
CCUserDefault *defaults = [CCUserDefault sharedManager];
defaults.intType = 1;
defaults.string = @"string";
...
取值
CCUserDefault *defaults = [CCUserDefault sharedManager];
NSLog(@"%d%@",defaults.intType,defaults.string);
CCUserDefault
类的所有成员变量存取都会映射到NSUserDefaults
中
- 添加类的所有属性前缀
- 添加黑名单
该项目最低支持 iOS 7.0
和 Xcode 8.0
。
CCUserDefaultsManager 使用 MIT 许可证,详情见 LICENSE 文件。