多控制器之间的跳转和数据存储
连线跳转方式,根据绑定的 ID 进行控制器跳转数组
[self performSegueWithIdentifier:@"jumpToContact" sender:nil];
而后系统会调用atom
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
向下一个控制器顺序传递数据,能够在此方法中编写
spa
代码方式跳转code
/** 取出 storyboard 中 ID 为"edit"的控制器*/UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"Main" bundle:nil]; XBEditViewController *vc = [storyboard instantiateViewControllerWithIdentifier:@"edit"];/** 向控制器传递数据 */vc.contact = self.contacts[indexPath.row]; vc.block = ^{ [self.tableView reloadData]; };/** 压栈跳转控制器 */[self.navigationController pushViewController:vc animated:YES];
Modalorm
效果:默认是新控制器从屏幕的最底部往上钻,直到盖住以前的控制器为止对象
加载新控制器同步
- (void)presentViewController:(UIViewController *)viewControllerToPresent animated: (BOOL)flag completion:(void (^)(void))completion
关闭控制器string
- (void)dismissViewControllerAnimated: (BOOL)flag completion: (void (^)(void))completion;
plist 数据存储
Plist注意:不能存储自定义对象it
Plist:数组和字典io
如何判断一个对象能不能使用Plist,就看下有没有writeToFile
NSArray *arr = @[@"1234",@1]; // 获取应用的文件夹(应用沙盒) // NSString *homePath = NSHomeDirectory(); // 获取temp // NSTemporaryDirectory(); // 获取Cache文件路径 // NSSearchPathDirectory:搜索的目录 // NSSearchPathDomainMask:搜索范围 NSUserDomainMask:表示在用户的手机上查找 // expandTilde 是否展开全路径,若是没有展开,应用的沙盒路径就是~ // 存储必定要要展开路径 NSString *cachePaht = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES)[0]; // 拼接文件名 NSString *filePath = [cachePaht stringByAppendingPathComponent:@"personArr.plist"]; // File:文件的全路径 [arr writeToFile:filePath atomically:YES]; // 文件读取 NSArray *array = [NSArray arrayWithContentsOfFile:filePath];
完成写入
写入效果图
偏好设置存储
偏好设置存储好处:
1 不须要关心文件名
2 快速作键值对存储底层:就是封装了一个字典
NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults] ; [userDefaults setObject:@"sxb" forKey:@"account"]; [userDefaults setObject:@"123" forKey:@"password"]; [userDefaults setBool:YES forKey:@"rmbPwd"]; // 在iOS7以前,默认不会立刻把跟硬盘同步 // 手动同步// [userDefaults synchronize];
读取
NSString *pwd = [[NSUserDefaults standardUserDefaults] objectForKey:@" password"];
自定义对象的归档
归档能够存储本身定义的对象
Person *p = [[Person alloc] init]; p.age = 18; // 获取cache NSString *cachePath = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES)[0]; // 获取文件的全路径 NSString *filePath = [cachePath stringByAppendingPathComponent:@"person.data"]; // 把自定义对象归档 [NSKeyedArchiver archiveRootObject:p toFile:filePath]; // 解档 Person *p = [NSKeyedUnarchiver unarchiveObjectWithFile:filePath];
同时 若是一个自定义对象想要归档,必须遵照NSCoding协议
@interface Person : NSObject<NSCoding>
而且实现协议,描述归档和解档的属性
@implementation Person// 何时调用:自定义对象归档的时候// 做用:用来描述当前对象里面的哪些属性须要归档- (void)encodeWithCoder:(NSCoder *)aCoder { // name [aCoder encodeObject:_name forKey:@"name"]; // age [aCoder encodeInt:_age forKey:@"age"]; }// 何时调用:解档对象的时候调用// 做用:用来描述当前对象里面的哪些属性须要解档// initWithCoder:就是用来解析文件的。- (id)initWithCoder:(NSCoder *)aDecoder { // super:NSObject if (self = [super init]) { // 注意:必定要给成员变量赋值 // name _name = [aDecoder decodeObjectForKey:@"name"]; // age _age = [aDecoder decodeIntForKey:@"age"]; } return self; }