framework中关于资源的读取

背景介绍

最近推动了最低支持iOS8的事情,并且引入了framework进行部门间合作的机制。整体上,这件事值得做,比以前能少不少麻烦,未来的发展也将更顺畅。不过,跟直接加一个文件夹相比,引入了framework,就像加了一堵墙,有些以前很方便的事情现在也变得麻烦了。比如,资源文件的管理和读取就是其中之一。

是否需要Bundle?

  • 以前的.a静态库是不能包含资源文件的。所以毫无疑问,如果需要xib, img等资源文件的话,需要打包在.bundle中,和.a一起发布,一般保持两者同样的名字。

  • 从iOS8开始,可以用framework,并且可以包含资源文件,可以放弃.bundle文件了。这主要是从使用方便的角度来讲的。将代码和资源分离,完成同一功能要找两个地方,自找麻烦。

  • 在framework中开发,就像跟主程序中开发一样,按照功能分模块,划分文件夹。将同一功能的文件都放在一个文件夹中,包括Storyboard,xib,image,Code等等,以最短路径获取所需要的信息。

  • 将framework和bundle分两个隔离是不合理的,同样,在framework中包含一个bundle同样也是不合理的。模块间隔离的单位是framework,在framework内部,应该考虑充分共享以及获取的方便性,再引入第二级的bundle,只能是自我设限,得不偿失。让.bundle和.a成为历史,全面使用framework。

  • 还有一种情况,就是当资源的体积很大的时候,比如视频、地图之类的。这种时候,将资源单独放在一个bundle中,与程序分离,可以不同时间发布,也不用重新发版本,有一定的意义。不过,对于大资源,直接以文件的形式下载就可以了,有必要用bundle多包一层吗?

  • 除了主程序,其他framework的地位都是平等的,不存在framework之中包含framework的概念。取而代之的,是依赖关系。所以,整体架构在物理上就两层,主程序和framework。逻辑上的层次和包含等概念,都要理解依赖。比如要开发一个Network.framwork,需要用到AFNetworking.framework。在逻辑上是主程序-》Network.framwork-》AFNetworking.framework。但是在物理上的关系是
    主程序-》Network.framwork和主程序-》AFNetworking.framework。AFNetworking.framework与Network.framwork地位是完全平等的,只不过想用Network.framwork的程序必须同时将AFNetworking.framework包含进来。

  • 可以把framework想象为主程序中的一个文件夹。在没有framework的主程序中,资源是直接放在根目录下的。但是,引入了framework之后,就像把资源移动了相应的子目录。这样路径就发生了变化,NSBundle这个类就是为了区分这种变化。

在framework里面读framwork自己的资源文件

这是framework内部的资源,跟其他都没有关系。但是framework不能单独存在,必须要放在某个“主程序”中才能起作用。bundle参数如果不传,那么默认是mainBundle,这种情况路径就不对了。这种情况下,可以用下面这个API来获得bundle参数。

+ (NSBundle *)bundleForClass:(Class)aClass;
    // 获取bundle参数
    NSBundle *bundle = [NSBundle bundleForClass:self.class];
    // 读UIStoryboard
    UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@“StoryboardName” bundle:bundle];
    // 读UIImage
    UIImage *image = [UIImage imageNamed:@"icon_back_gray" inBundle:bundle compatibleWithTraitCollection:nil];
    // 文件路径
    NSString* htmlPath = [bundle pathForResource:@"index" ofType:@"html"];

在主程序中读framework里面的资源文件

同样也是利用bundle参数来读取,class选择framework中某个导出的class就可以了。

    // 获取bundle参数,ZAFinanceFrameworkManager是framework中接口类
    NSBundle *bundle = [NSBundle bundleForClass:[ZAFinanceFrameworkManager class]];

在framework中读主程序的资源文件

这个和在主程序中读自己的一样,不需要bundle参数,一定要传的话,就传nil或者[NSBundle mainBundle]

从framework里面读其他framwork里面的资源文件

同样也是利用bundle参数来读取,class选择目标framework中某个导出的class就可以了。

小结

在单体程序中,NSBundle这个参数不需要管,全部传nil或者是默认的[NSBundle mainBundle]就可以了。

引入了framework之后,就需要NSBundle这个参数来区分资源所在的模块。确定NSBundle比较简单的方法是用下面这个API,其中的class只要选择资源所在的framework中的某个class就可以了。如果是Swift,并且不是类类型,那么就可以用“self.dynamicType”来取得类型。

+ (NSBundle *)bundleForClass:(Class)aClass;

关于模块划分的原则

苹果的指导原则是MVC,在大多数情况是合适的,客户端都比较小,几个页面跳转一下,加几个动画就差不多了。
近来,随着移动设备性能的提升,手机越来越像电脑了,手机客户端也越来越重,慢慢地跟PC端客户端一样。
程序变大了,为了便于维护,就要想办法划分模块,PC端经历过的事情很快就在手机端重演。
从iOS8开始,苹果提供了动态链接库framework,这个就相当于PC端的dll。手机客户端的组件化、平台化也像在PC端那么方便了。

参考文章

自己创建Cocoa touch FrameWork

Load image from iOS 8 framework

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 关于 动态库 & 静态库 ,参考下面文章:iOS开发关于"框架"的那些事iOS 静态库,动态库与 Framewor...
    曦风兮阅读 1,439评论 2 2
  • 静态库与动态库的区别 首先来看什么是库,库(Library)说白了就是一段编译好的二进制代码,加上头文件就可以供别...
    吃瓜群众呀阅读 11,859评论 3 42
  • 仅以方便自己查阅记录前言1.静态库和动态库有什么异同?静态库:链接时完整地拷贝至可执行文件中,被多次使用就有多份冗...
    190CM阅读 4,157评论 0 4
  • 框架捆绑 框架是封装动态共享库和支持该库所需的资源文件的分层目录。框架比典型的动态共享库提供了一些优势,因为它们为...
    nicedayCoco阅读 1,598评论 0 2
  • 数算恩福 1.感恩滴滴快车师傅,大雨送我到高铁站,谢谢,谢谢,谢谢! 2.感恩高铁,可以快速的去我想去的地方,谢谢...
    Lionheart蘭阅读 331评论 0 1