前言
最近公司新開(kāi)了個(gè)項(xiàng)目,需要從零開(kāi)始搭建,之前做過(guò)一些組件化的工作,但是之前的開(kāi)發(fā)語(yǔ)言是OC,新項(xiàng)目切換到了Swift,雖然差異不大,但是還是寫(xiě)了本文作為記錄
tips: 這篇文章寫(xiě)得不錯(cuò) iOS swift的xcworkspace多項(xiàng)目管理(架構(gòu)思想)
正如文章中所說(shuō),多工程需要面臨的幾個(gè)問(wèn)題
- 各個(gè)工程如何創(chuàng)建,如何維護(hù)第三方的依賴(lài)(這里使用Cocopods進(jìn)行依賴(lài)管理)
- 主工程如何調(diào)用Library工程
- Library之前的依賴(lài)和調(diào)用
跟著我走一遍流程,follow me, Let's start it!
正文
一、主工程創(chuàng)建
首先,我們創(chuàng)建一個(gè)普通工程

然后集成 Cocopods
step1: cd /Volumes/SubMadao/git4Madao/ularization/ (你的工程目錄)
step2: pod init
然后編輯 podfile
platform:ios,'8.0'
inhibit_all_warnings!
use_frameworks!
# workspace
def workspace_pods
end
target 'Modularization' do
workspace_pods
target 'ModularizationTests' do
inherit! :search_paths
end
target 'ModularizationUITests' do
inherit! :search_paths
end
end
step3: pod install

那么,我們的工作空間(WorkSpace)也就創(chuàng)建好了,其實(shí)也就是Cocopods集成的基本流程
二、Library創(chuàng)建和關(guān)聯(lián)
我們暫定各個(gè)模塊如下(借鑒他人):
- 主工程:承載主要的表層業(yè)務(wù)代碼
- Core:獨(dú)立存在,應(yīng)用加密,接口請(qǐng)求認(rèn)證等敏感代碼
- Base:基類(lèi)封裝,拓展,基本的數(shù)據(jù)處理
- Service:服務(wù)層,封裝業(yè)務(wù)工具類(lèi),網(wǎng)絡(luò)層服務(wù),持久化層服務(wù)等
- Pods: 三方依賴(lài)

創(chuàng)建各個(gè)Base ,Service ,Core等Library
new project 新建一個(gè)工程并選擇 Cocoa Touch Framework類(lèi)型

加入正確的 Group和 WorkSpace

然后需要將 Mach-O Type 修改為靜態(tài)庫(kù) Static Library

如此重復(fù),創(chuàng)建 Base ,Service ,Core

到這里,項(xiàng)目架構(gòu)的基本雛形已經(jīng)出來(lái)了,但是工程中各個(gè)Library之間并沒(méi)有相互依賴(lài)的關(guān)系
三、主工程調(diào)用Library

Linked Frameworks Libraries 中添加即可,添加之后,只需要Build主工程,Library能夠自動(dòng)聯(lián)編

很自然地,我們需要在主工程中調(diào)用Library中的文件,那么我們?cè)?MADCore 中添加一個(gè)文件
/// MADCoreSettings.swift
import UIKit
// 類(lèi)需要聲明為 Public
public class MADCoreSettings: NSObject {
// 屬性需要聲明為 Public
public static let SECRET_KEY = "SECRET_KEY"
}
還需要在 Building Phases 中的 Headers 中添加為 Public

import UIKit
import MADCore
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// 調(diào)用 MADCore庫(kù)文件
let key = MADCoreSettings.SECRET_KEY
}
}
這樣子,只需要 import MADCore 即可調(diào)用 MADCore 庫(kù)中的文件了
四、子工程Library互相調(diào)用
也和主工程調(diào)用Library類(lèi)似,對(duì)應(yīng)添加依賴(lài)即可,暴露header即可
五、Cocopods 管理主工程和 Library的三方依賴(lài)
我們需要在 Service 中 封裝網(wǎng)絡(luò)層的代碼,那么我們需要用Cocopods為L(zhǎng)ibrary添加三方依賴(lài)
platform:ios,'8.0'
inhibit_all_warnings!
use_frameworks!
workspace 'Modularization.xcworkspace'
######################################## dependency
# workspace
def workspace_pods
# react
pod 'RxSwift'
pod 'RxCocoa'
# orm
pod 'ObjectMapper', '~> 3.3.0'
pod 'SwiftyJSON'
end
# main project dependency
def project_only_pods
pod 'SnapKit', '~> 4.0.0'
pod 'Kingfisher', '~> 4.0'
pod 'MJRefresh'
pod 'MJExtension'
pod 'MD-UITableView+FDTemplateLayoutCell'
pod 'SVProgressHUD', '2.0.4'
end
# network layer dependency
def network_layer_pods
pod 'Moya/RxSwift', '~> 11.0'
pod 'Moya', '~> 11.0.2'
pod 'Alamofire', '~> 4.5'
end
######################################## main project
target 'Modularization' do
workspace_pods
project_only_pods
network_layer_pods
target 'ModularizationTests' do
inherit! :search_paths
end
target 'ModularizationUITests' do
inherit! :search_paths
end
end
######################################## Library
# Service
target 'MADService' do
project 'MADService/MADService.xcodeproj'
#
workspace_pods
network_layer_pods
end
# Base
target 'MADBase' do
project 'MADBase/MADBase.xcodeproj'
#
workspace_pods
end
# Core
target 'MADCore' do
project 'MADCore/MADCore.xcodeproj'
#
workspace_pods
end
需要注意的兩行是
workspace 'Modularization.xcworkspace'
project 'MADService/MADService.xcodeproj'
project 'MADBase/MADBase.xcodeproj'
project 'MADCore/MADCore.xcodeproj'
接下來(lái)只需要 pod install 即可完成我們的配置依賴(lài)
分別配置了 workspace 的文件路徑, 和子project的路徑
以此為基礎(chǔ),使用 Moya + RxSwift 封裝了網(wǎng)絡(luò)層的請(qǐng)求代碼,僅供參考

最后
到這里,我們已經(jīng)完成了組件化的基本操作和配置,只要愉快地填充代碼就可以啦,常規(guī)慣例Demo傳送門(mén):GITHUB