• 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];
    }
    
    • 过程示意图
  • 相关阅读:
    Win7系统下搭建Tomcat服务器
    转:在线框架引用 bootstrap/jq/jqmobile/css框架
    转:Web.config配置文件详解
    转:HTML和Web窗体的区别
    在VS2010中创建网站并发布
    nohup 借助cronolog进行日志分割 Linux
    Linux (centos 8) 安装nginx1.20
    Ubuntu 安装使用yum--转载
    C# 字符串插值内部工作原理
    Linux 安装MySQL
  • 原文地址:https://www.cnblogs.com/ShaRuru/p/5024493.html
Copyright © 2020-2023  润新知