iOS組件化之使用pod命令創(chuàng)建組件

前言

前幾篇博客描述了手動(dòng)創(chuàng)建組件的方法蹦漠,到新公司發(fā)現(xiàn)這種方式不適合小公司快捷方便的需求檩咱,所以轉(zhuǎn)而向cocoapods為我們提供的pod lib命令來(lái)創(chuàng)建組件辛润,這樣對(duì)于沒(méi)接觸過(guò)組件化的新人比較友好,另外也確實(shí)少了很多自己需要配置的各種東西解幼。

準(zhǔn)備

  • 組件創(chuàng)建需要cocoapods
  • 如果想上傳到倉(cāng)庫(kù)還需要有git
  • 如果環(huán)境都沒(méi)搭建可以看下之前本序列的文章都有介紹

創(chuàng)建

1放仗、創(chuàng)建組件命令污桦,你可以CD到特定文件夾下執(zhí)行命令,創(chuàng)建名為名為Demo的組件為例

# 開(kāi)始執(zhí)行以下命令后會(huì)去github克隆模板代碼沒(méi)翻墻可能會(huì)比較慢
pod lib create  Demo

#創(chuàng)建過(guò)程中的選項(xiàng)可參考下面,有特殊也可以自己決定

What platform do you want to use?? [ iOS / macOS ]  平臺(tái)我們選擇iOS
 > iOS

What language do you want to use?? [ Swift / ObjC ]  語(yǔ)言我選擇oc
 > ObjC

Would you like to include a demo application with your library? [ Yes / No ]  是否創(chuàng)建demo工程
 > Yes

Which testing frameworks will you use? [ Specta / Kiwi / None ]  是否添加測(cè)試支持
 > None

Would you like to do view based testing? [ Yes / No ]  是否添加測(cè)試的view
 > No

What is your class prefix?  類(lèi)名使用的前綴
 > GG

當(dāng)前命令執(zhí)行完之后匙监,它會(huì)幫我們執(zhí)行pod install命令并自動(dòng)打開(kāi)里面的Example工程凡橱,我們先看下創(chuàng)建后文件夾目錄:

image.png
  • Demo文件夾是我們實(shí)際的組件目錄,后面創(chuàng)建的圖片及文件和源代碼都在這里
  • Demo文件夾下有兩個(gè)文件夾亭姥,一個(gè)Classes是存放代碼的地方在xcode創(chuàng)建的時(shí)候記得把代碼的目錄選擇放這里稼钩,一個(gè)是Assets存放不限于圖片的其他資源文件一般我們放圖片可以創(chuàng)建一個(gè)系統(tǒng)的.xcassets圖片管理器很方便存取
  • Demo.podspec是組件的描述,不懂可以看下之前的基本概念都是一樣的
  • Example 是我們調(diào)試使用的工程达罗,跟我們平時(shí)使用的項(xiàng)目差不多坝撑,只是它在Example/Podfile中幫我們加入了當(dāng)前組件的本地依賴(lài)方便我們調(diào)試

pod 'Demo', :path => '../'

  • .git是git相關(guān)的你可以刪掉它后續(xù)自己創(chuàng)建
  • .travis.yml是有關(guān)自動(dòng)化相關(guān)的也可以先忽略或者直接刪除

在xcode中的工程目錄:

image.png
  • 紅色部分是調(diào)試工程的目錄先不管他
  • 綠色部分就是我們?cè)谡{(diào)試的時(shí)候組件代碼具體呈現(xiàn)的地方静秆,Demo就是我們組件的名稱(chēng)有多個(gè)的話就是多個(gè)這樣的文件夾,Demo/Pod中的放的是組件的描述和README.md文件和實(shí)際的目錄是同步的

2巡李、創(chuàng)建好之后最好到項(xiàng)目根目錄下打開(kāi).gitgnore忽略文件中添加下列兩行抚笔,忽略我們?cè)跍y(cè)試的工程添加的依賴(lài)也上傳到git上

Example/Pods
Example/Podfile.lock

3、如果有自己的私有庫(kù)侨拦,在Example/Podfile中替換以下添加私有源殊橙,沒(méi)有的可以忽略這步

source 'git@xxxx/Specs.git'

4、上傳到倉(cāng)庫(kù)狱从,刪掉項(xiàng)目根目錄下的git文件夾膨蛮,使用以下命令將文件提交至git,嫌麻煩也可以直接使用Sourcetree來(lái)上傳

#當(dāng)組件的根目錄下
cd Demo
git init
#關(guān)聯(lián)內(nèi)網(wǎng)git倉(cāng)庫(kù)
git remote add origin git@xxxt/Demo.git
#提交源碼
git add .
git commit -m "Initial commit"
git push -u origin master

5季研、創(chuàng)建源代碼文件應(yīng)注意選擇路徑敞葛,還有對(duì)應(yīng)的target選擇

image.png

6、圖片的讀取問(wèn)題

  • 我們可以在xcode中選擇Asset Catalog來(lái)創(chuàng)建一個(gè)自己的圖片管理器与涡,名字最好用組件名稱(chēng)來(lái)命令好區(qū)分惹谐,一般存放在組件的Assets目錄下
image.png
  • 存放圖片的時(shí)候和我們一般項(xiàng)目中存儲(chǔ)的沒(méi)什么區(qū)別
  • 如果需要發(fā)布組件需要在podsepc中添加以下描述,以我的示例工程為例
 s.resource_bundles = {
     'Demo' => ['Demo/Assets/Demo.xcassets']
  }
  • 代碼獲取圖片我寫(xiě)了個(gè)工具類(lèi)驼卖,就是獲取bundle之后再獲取里面的圖片,使用方法也在里面了氨肌,使用這種方法Podfile需要去掉里面默認(rèn)添加的use_frameworks!,后續(xù)swift再作兼容
//
//  ResourceManager.h
//  AssetsKit
//
//  Created by GuoMS on 2019/2/18.
//

#import <Foundation/Foundation.h>

/* 使用方法款慨,新建一個(gè)文件,頭文件寫(xiě)入以下宏定義
 #import "ResourceManager.h"
 //自定義特定的名稱(chēng)
 #undef XXXBundle
 #define XXXBundle [ResourceManager resourceBundleForClass:[self class] podName:@"組件名稱(chēng)"]
 
 #undef BXXXImage
 #define BXXXImage(name) [ResourceManager imageName:name inBundle:XXXBundle]
 */



@interface BQSResourceManager : NSObject


/**
 獲取組件的bundle并緩存

 @param aClass 當(dāng)前調(diào)用的類(lèi)谬莹,用于定位bundle位置
 @param name 組件的名字
 @return bundle
 */
+ (NSBundle *)resourceBundleForClass:(Class)aClass
                             podName:(NSString *)name;



/**
 制定bundle獲取圖片

 @param name 圖片名字
 @param bundle bundle實(shí)例
 @return 圖片檩奠、為空返回nil
 */
+ (UIImage *)imageName:(NSString *)name
              inBundle:(NSBundle *)bundle;

@end
//
//  ResourceManager.m
//  AssetsKit
//
//  Created by GuoMS on 2019/2/18.
//

#import "ResourceManager.h"

@interface BQSResourceManager()

@property (strong, nonatomic) NSMutableDictionary *bundleDic;

@end

@implementation ResourceManager

+ (instancetype)sharedInstance {
    
    static BQSResourceManager *manager;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        manager = [[self alloc]init];
        manager.bundleDic = [NSMutableDictionary dictionary];
    });
    
    return manager;
    
}

+ (NSBundle *)resourceBundleForClass:(Class)aClass podName:(NSString *)name {
    
    NSAssert(aClass, @"class 不能為空");
    NSAssert(name.length > 0, @"組件名稱(chēng)不能為空");
    
    if (name.length <= 0 || !aClass) {
        return nil;
    }
    
    //獲取bundle
    NSBundle *cacheBundle = [[BQSResourceManager sharedInstance].bundleDic objectForKey:name];
    if (cacheBundle) {
        return cacheBundle;
    }
    
    NSBundle *bundle = [NSBundle bundleForClass:aClass];
    if (bundle) {
        NSString *resourceBundlePath = [bundle pathForResource:name ofType:@"bundle"];
        if (resourceBundlePath && [[NSFileManager defaultManager] fileExistsAtPath:resourceBundlePath]) {
            bundle = [NSBundle bundleWithPath:resourceBundlePath];
        }
        [[BQSResourceManager sharedInstance].bundleDic setObject:bundle forKey:name];
        
        return bundle;
    }
    
    return nil;
}


+ (UIImage *)imageName:(NSString *)name
              inBundle:(NSBundle *)bundle {
    
    NSAssert(bundle, @"bundle 不能為空");
    NSAssert(name.length > 0, @"圖片名稱(chēng)不能為空");
    if (name.length <= 0 || !bundle) {
        return [UIImage new];
    }
    
    UIImage * image = [UIImage imageNamed:name
                                 inBundle:bundle
            compatibleWithTraitCollection:nil];
    
    return image;

}


@end


最后添加了新的頭文件之后有時(shí)候在Example工程中導(dǎo)入會(huì)提示找不到頭文件,可以重新執(zhí)行pod install就可以找到了

如果你有遇到什么問(wèn)題歡迎在評(píng)論中回復(fù)附帽,我看到的都會(huì)回

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末埠戳,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蕉扮,更是在濱河造成了極大的恐慌整胃,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喳钟,死亡現(xiàn)場(chǎng)離奇詭異屁使,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)奔则,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)蛮寂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人易茬,你說(shuō)我怎么就攤上這事酬蹋〖袄希” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵范抓,是天一觀的道長(zhǎng)骄恶。 經(jīng)常有香客問(wèn)我,道長(zhǎng)匕垫,這世上最難降的妖魔是什么僧鲁? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮年缎,結(jié)果婚禮上悔捶,老公的妹妹穿的比我還像新娘。我一直安慰自己单芜,他們只是感情好蜕该,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著洲鸠,像睡著了一般堂淡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上扒腕,一...
    開(kāi)封第一講書(shū)人閱讀 49,950評(píng)論 1 291
  • 那天绢淀,我揣著相機(jī)與錄音,去河邊找鬼瘾腰。 笑死皆的,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蹋盆。 我是一名探鬼主播费薄,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼栖雾!你這毒婦竟也來(lái)了楞抡?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤析藕,失蹤者是張志新(化名)和其女友劉穎召廷,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體账胧,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡竞慢,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了治泥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梗顺。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖车摄,靈堂內(nèi)的尸體忽然破棺而出寺谤,到底是詐尸還是另有隱情仑鸥,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布变屁,位于F島的核電站眼俊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏粟关。R本人自食惡果不足惜疮胖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望闷板。 院中可真熱鬧澎灸,春花似錦、人聲如沸遮晚。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)县遣。三九已至糜颠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間萧求,已是汗流浹背其兴。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留夸政,地道東北人元旬。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像守问,于是被迫代替她去往敵國(guó)和親匀归。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350