使用CocoaPods創建自己的私有庫-iOS組件化第一步

来源:https://www.cnblogs.com/anywherego/archive/2019/07/08/11149609.html
-Advertisement-
Play Games

目前iOS組件化常用的解決方案是Pod+路由+持續集成,通常架構設計完成後第一步就是將原來工程里的模塊按照架構圖分解為一個個獨立的pod工程(組件),今天我們就來看看如何創建一個Pod私有庫。 新建:pod lib create 假設我們需要創建的庫名為TestLib,下麵我們使用Pod官方提供的創 ...


目前iOS組件化常用的解決方案是Pod+路由+持續集成,通常架構設計完成後第一步就是將原來工程里的模塊按照架構圖分解為一個個獨立的pod工程(組件),今天我們就來看看如何創建一個Pod私有庫。

新建:pod lib create

假設我們需要創建的庫名為TestLib,下麵我們使用Pod官方提供的創建模板:

首先進入我們的工作目錄,如workspace,輸入命令

pod lib create TestLib

創建過程中需要填寫幾個問題,如下圖所示,按個人所需填寫:

創建完成以後工程會自動打開,Xcode目錄和實際路徑有一定區別,截圖如下:

解決這個問題也很簡單,將文件夾作為Group拖動到Xcode中即可:(如果Xcode工程中本身已經包含Classes目錄,可以忽略這一步)

然後刪除ReplaceMe.swift文件,在Class目錄創建一個名為TestClass的swift文件:

在TestClass中定義ClassA和ClassB,註意其中一個是public的

import Foundation

public class ClassA {   //這是public類,可被外部工程訪問
    public let name = "ClassA"
    let age = 18
}

class ClassB {  //不是public類,不能被外部工程訪問
    let name = "ClassB"
}

重要:為了讓改動生效,一定要重啟Xcode一次,然後在Example工程下執行(有時Xcode不會更新Pod代碼,需要重啟)

pod install

就可以在代碼中調用新寫的類,註意到只能調用public修飾的屬性

到這裡使用Pod新建一個私有庫就完成了。

驗證: pod lib lint (podspec配置文件說明)

新建完成後,我們還需要驗證,需要修改配置文件,通過下麵的截圖路徑找到新建的私有庫的配置文件:

或者在Xcode里的:

文件內容:

#
# Be sure to run `pod lib lint TestLib.podspec' to ensure this is a
# valid spec before submitting.
#
# Any lines starting with a # are optional, but their use is encouraged
# To learn more about a Podspec see https://guides.cocoapods.org/syntax/podspec.html
#

Pod::Spec.new do |s|
  
  # 名稱、版本號、概述
  s.name             = 'TestLib'
  s.version          = '0.1.0'
  s.summary          = 'A short description of TestLib.'

# This description is used to generate tags and improve search results.
#   * Think: What does it do? Why did you write it? What is the focus?
#   * Try to keep it short, snappy and to the point.
#   * Write the description between the DESC delimiters below.
#   * Finally, don't worry about the indent, CocoaPods strips it!

# 詳細描述
  s.description      = <<-DESC
TODO: Add long description of the pod here.
                       DESC

  # 主頁、截圖、license證書、作者信息、源代碼地址、社交地址
  s.homepage         = 'https://github.com/xxx/TestLib'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'xxx' => '[email protected]' }
  s.source           = { :git => 'https://github.com/xxx/TestLib.git', :tag => s.version.to_s }
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'

  # iOS版本
  s.ios.deployment_target = '8.0'

  # 源碼所在路徑
  s.source_files = 'TestLib/Classes/**/*'
  
  # 資源文件所在地址
  # s.resource_bundles = {
  #   'TestLib' => ['TestLib/Assets/*.png']
  # }

  # 對外公開的h文件地址,swift一般用不到
  # s.public_header_files = 'Pod/Classes/**/*.h'
  
  # 包含的系統framework
  # s.frameworks = 'UIKit', 'MapKit'
  
  # 包含的第三方pod
  # s.dependency 'AFNetworking', '~> 2.3'
end

更詳細的介紹可以訪問官網https://guides.cocoapods.org/syntax/podspec.html

配置好以後我們需要做一次驗證,在工程目錄下使用命令

pod lib lint

初次驗證可能遇到的幾個問題:

  • Could not find a `ios` simulator (valid values: ). Ensure that Xcode -> Window -> Devices has at least one `ios` simulator listed or otherwise add one.
    這個問題是pod依賴的組件fourflusher與xcode版本不匹配造成的,可以使用如下命令更新
1.sudo gem uninstall fourflusher
2.sudo gem install fourflusher

必要的話還需要更新pod

sudo gem update cocoapods
  • [!] TestLib did not pass validation, due to 3 warnings (but you can use `--allow-warnings` to ignore them).
    pod驗證發現3個及以上的warning就會報這個錯,如果只是驗證一下工程,能確保對外發佈之前能修複,可以使用--allow-warnings

pod lib lint --allow-warnings

如果驗證通過,會看到TestLib passed validation.,到這一步既完成驗證

版本:iOS和Swift管理

通過pod官方模板做出來的工程iOS版本為8.0,Swift版本為4.0,我們有時需要根據需要修改版本號,需要在spec文件中添加:

  # iOS版本
  s.ios.deployment_target = '9.0'

  # Swift版本
  s.swift_versions = '5.0'

然後執行pod install更新工程即可

Git上傳到私有庫

現在私有Git伺服器創建TestLib項目,然後回到工程目錄,使用Git初始化命令:

git init
git remote add origin http://私有倉庫地址/TestLib.git
git add .
git commit -m 'init'
git push -u origin master

然後修改spec文件內容

  # 主頁、截圖、license證書、作者信息、源代碼地址、社交地址
  s.homepage         = 'http://私有庫地址/TestLib.git'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'xxx' => '[email protected]' }
  s.source           = { :git => 'http://私有庫地址/TestLib.git', :tag => s.version.to_s }

如果需要對外發佈版本時需打tag,然後創建同名branch

git tag -a 0.1.0 -m '0.1.0'
git branch 0.1.0

打包:pod package

有時我們不希望提供源代碼,只提供framework給外部調用,可以使用package,首先安裝pod插件:

sudo gem install cocoapods-packager

package參數:

參數名 註釋
--force 覆蓋之前的文件
--no-mangle 1.表示不使用name mangling技術,pod package預設是使用這個技術的。我們能在用pod package生成二進位庫的時候會看到終端有輸出Mangling symbols和Building mangled framework。表示使用了這個技術。2.如果你的pod庫沒有其他依賴的話,那麼不使用這個命令也不會報錯。但是如果有其他依賴,不使用--no-mangle這個命令的話,那麼你在工程里使用生成的二進位庫的時候就會報錯:Undefined symbols for architecture x86_64。
--embedded 生成靜態framework
--library 生成靜態.a
--dynamic 生成動態framework
--bundle-identifier 動態framework需要的簽名
--exclude-deps 不包含依賴的符號表,生成動態庫的時候不能包含這個命令,動態庫一定需要包含依賴的符號表
--configuration 表示生成的庫是debug還是release,預設是release。--configuration=Debug
--subspecs 如果你的pod庫有subspec,那麼加上這個命名錶示只給某個或幾個subspec生成二進位庫,--subspecs=subspec1,subspec2。生成的庫的名字就是你podspec的名字,如果你想生成的庫的名字跟subspec的名字一樣,那麼就需要修改podspec的名字。 這個腳本就是批量生成subspec的二進位庫,每一個subspec的庫名就是podspecName+subspecName。
--spec-sources=private,https://github.com/CocoaPods/Specs.git 一些依賴的source,如果你有依賴是來自於私有庫的,那就需要加上那個私有庫的source,預設是cocoapods的Specs倉庫。--spec-sources=private,https://github.com/CocoaPods/Specs.git。

可以使用下麵的命令打包:

pod package TestLib.podspec --force

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Redis主從複製機制詳解 Redis有兩種不同的持久化方式,Redis伺服器通過持久化,把Redis記憶體中持久化到硬碟當中,當Redis宕機時,我們重啟Redis伺服器時,可以由RDB文件或AOF文件恢復記憶體中的數據。 不過持久化後的數據仍然只在一臺機器上,因此當硬體發生故障時,比如主板或CPU壞 ...
  • 第0步:版本選擇 AOSP版本選擇很重要,如果選錯了,會造成編譯失敗等各種問題,編譯AOSP對Xcode的版本是有要求的; 比如:AOSP6.0 7.0,要求Xcode的版本是8.3,然而在MacOS 10.14上面是不支持Xcode8.3的這就很尷尬; 由於現在大家的Mac環境基本是更新到最新的1 ...
  • 在Dart裡面,變數的聲明使用var、Object或Dynamic關鍵字,如下所示: var name = ‘張三’; 在Dart語言里一切皆為對象,所以如果沒有將變數初始化,那麼它的預設值為null(包括數字),如果需要判斷變數是否為null,則需要進行如下判斷: String name;if(n... ...
  • iOS查看屏幕幀數工具--YYFPSLabel iOS 保持界面流暢的技巧 iOS 優化界面流暢度的探討 先研究一下 改天自己出一篇文章 ...
  • 原文:https://www.jianshu.com/p/b5a484cecd7c 本文主要說明2018年蘋果開發者賬號申請的流程,申請流程相較於2017年有一些改變,希望大家能夠通過本文少走一些彎路,能夠順利完成開發者賬號的申請。關於新流程中可能出現的一些問題以及部分流程的變更均在下文中運用灰色塊 ...
  • 一、數據綁定 二、列表渲染 <!--index.wxml--> 三、綁定一個點擊事件 四、事件冒泡 五、事件傳參 ...
  • 系統自帶的分段選擇就是 UISegmentedControl ,也有一些大佬自定義的 Segmented ,比如Git上的 HMSegmentedControl ,我以前最初的項目中,也有用到過,如果自己寫,或者想自定義一些UI,該從哪裡出發,其實在用過 HMSegmentedControl 之後, ...
  • 第一步:手機連接到itunes 選擇本電腦備份 備份的時候不要加密 然後立即備份 第二步:前往文件夾,找到itunes的備份路徑~/Library/Application Support/MobileSync/Backup 在這目錄下搜索 3d0d開頭的文件,這就是 iPhone 簡訊的資料庫文件。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...