Plist文件与数据解析

综述

  • 初步阶段当我们做个需要点数据的练习时(比如购物商品展示),我们可能是将数据直接写在代码中,比如说定义一个字符串数组或存放字典的数组。但这其实并不是一种合理的做法。因为如果当数据修改的时候,就要经常翻开对应的代码进行修改,造成代码扩展性低。
  • 因此,可以考虑将经常变的数据放在文件中进行存储,程序启动后从文件中读取最新的数据。如果要变动数据,直接修改数据文件即可,这样就不用修改代码。
  • 一般可以使用属性列表文件存储NSArray或者NSDictionary之类的数据,这种“属性列表文件”的扩展名是plist,因此也称为“plist文件”

在Xcode中创建plist文件



  • 为方便测试,编辑plist文件添入一个存放字典的数组

Plist文件的加载

  • 通过代码来解析Plist文件中的数据
//首先获得Plist文件的全路径
NSBundle *bundle = [NSBundle mainBundle];
NSString *path = [bundle pathForResource:@"shops" ofType:@"plist"];
//根据plist根节点数据类型,定义相对应的类型去接收它,这儿_shops是数组类型
_shops = [NSArray arrayWithContentsOfFile:path];

字典转模型

  • 上面我们通过加载plist文件,获得了一个存放字典的数组,假设每个字典对应一个商品的数据,这时我们可以通过访问数组与字典的相关方法去获取数据
dict[@"name"] = @"apple";
NSString *name = dict[@"name"];
  • 但这样存在一些不好的地方,比如其中字符串key是需要我们手敲,key容易写错,Key如果写错了,编译器不会有任何警告和报错,造成设错数据或者取错数据
  • 实际开发中会使用模型来接收这些数据,模型其实就是指定义一个类,比如商品类,这样商品名称name就是它的成员属性,需要接收数据时 ,就以此类为模板新建实例对象去接收,然后再将这个对象存放到专门的对象数组中
  • 用模型来表示数据会更加专业,模型设置数据和取出数据都是通过它的属性,属性名如果写错了,编译器会马上报错,因此保证了数据的正确性
  • 使用模型访问属性时,编译器会提供一系列的提示,提高编码效率
product.name = @"apple";
NSString *name = product.name;
  • 字典转模型的过程最好封装在模型内部,提供一个可以传入字典参数的构造方法
-(instancetype)initWithDict:(NSDictionary *)dict
{
    if (self = [super init]) {
        self.icon = dict[@"icon"];
        self.name = dict[@"title"];
    }
    return self;
}
+(instancetype)productWithDict:(NSDictionary *)dict
{
    return [[self alloc] initWithDict:dict];
}
  • 过程示意图
posted on 2015-12-06 21:59  夏鲁鲁  阅读(2450)  评论(0编辑  收藏  举报