iOS开发swift的framework制作

摘要

公司项目采用组件化开发,在查阅资料与业务分析后,采用了framework+路由跳转方案实现。如把单独完整的业务功能封装成SDK的形式放到壳工程集成实现,其它无需封装的,采用路由跳转跳转到想的页面,sdk内部,后续也实现路由跳转。本文主要讲述iOS的framework的打包方式。分为以下几点讲述:

  • swift纯代码简单封装sdk
  • swfit纯代码+bundle封装sdk
  • swift+oc纯代码封装sdk
  • swift+oc+bundel封装sdk
  • swift+oc+cocoapods引用第三方封装sdk

为了更好的开发sdk并测试,我们把sdk工程以及测试此sdk的工程添加到同一个工程空间中进行开发。如下:

  • 创建空白工程


    iOS开发swift的framework制作_第1张图片
    1新建空白工程.png
  • 创建sdk工程


    iOS开发swift的framework制作_第2张图片
    2新建SDK项目工程.png
  • 建成功后如下图所示


    iOS开发swift的framework制作_第3张图片
    3建成后如下图所示.png
  • 创建测试sdk的demo工程


    iOS开发swift的framework制作_第4张图片
    4测试工程创建.png
  • 拖动测试工程到第一步所创建的工作空间中


    5拖动测试工程到工作空间.png
  • 最终效果如下


    iOS开发swift的framework制作_第5张图片
    6拖动结束后效果.png

一、swift纯代码简单封装sdk

  • build setting中设置打包方式为静态库


    iOS开发swift的framework制作_第6张图片
    7配置build setting mach-O Type.png
  • 在sdk工程中,创建或添加你要封装的源文件,这里,我是创建随意创建一个view。如果想要这个类或类里面的方法被外面使用,需要配合pubic修饰供外面使用
    iOS开发swift的framework制作_第7张图片
    6编写sdk.png
  • 编译打包,在工程的scheme中,选择要运行的target。


    iOS开发swift的framework制作_第8张图片
    6dabao.png

    打包完成后,products中,framework后缀结尾的包文件会由红变为黑色。


    iOS开发swift的framework制作_第9张图片
    8打包成功.png
  • 测试
    上一步中,右击show in finder,然后把这个framework文件拖入的测试demo中
    iOS开发swift的framework制作_第10张图片
    9拖入测试.png

    注意:这里建议选择create folder references,只引用,不把包真正的拖入项目中。因为这样,下次就不用再拖入了。在sdk工程修改了sdk源代码,只要重新编译sdk,然后切换demo工程直接运行,sdk中的改变在demo中是可以同步的。
  • 附上代码,demo中的viewController与YLXHomeView
// SDK中源文件YLXHomeView.swift
import UIKit

// MARK: 自定义的一个首页视图
public class YLXHomeView: UIView {

    override public init(frame: CGRect) {
        super.init(frame: frame)
        setupUI()
        layout()
    }
    
    required public init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
    // MARK: 配置页面
    func setupUI() {
        addSubview(iconImgV)
    }
    // 布局页面
    func layout() {
        iconImgV.frame = CGRect.init(x: 0, y: 0, width: self.frame.size.width, height: self.frame.size.height)
    }
    lazy var iconImgV: UIImageView = {
        let view = UIImageView.init()
        view.backgroundColor = UIColor.red
        return view
    }()
}


// demo中ViewController.swift
import UIKit
import SDKFramework

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        
        setupUI()
    }

    // MARK: 配置页面
    func setupUI() {
        view.addSubview(homeV)
    }
    
    // MARK: 懒加载
    lazy var homeV: YLXHomeView  = {
        let view = YLXHomeView.init(frame: CGRect.init(x: 20, y: 20, width: 200, height: 50))
        return view
    }()
}
  • 效果


    iOS开发swift的framework制作_第11张图片
    10-1.png

纯swift的demo地址

二、swfit纯代码+bundle封装sdk

未完待续

三、swift+oc纯代码封装sdk

  • swift中调用oc
    • 在SDKFramework.h中添加import导入
#import 
  • oc中调用swift代码。
    • 在oc的m或h文件中,导入
#import 
  • 示例


    iOS开发swift的framework制作_第12张图片
    Snip20181218_3.png

    iOS开发swift的framework制作_第13张图片
    Snip20181218_2.png

swift+oc纯代码的demo地址

未完待续

四、swift+oc+bundel封装sdk

未完待续

五、swift+oc+cocoapods引用第三方封装sdk

未完待续

模拟器的framework与真机的framework合并

在终端运行下面命令

lipo -create 模拟器framework路径  真机framework路径 -output 新生成要存放的路径

你可能感兴趣的:(iOS开发swift的framework制作)