OC与Swift混编,三种场景的实现方式

多语言并存时期,混编成为一种必须的方式 ,在多场影中实现OC和Swift语言的并存原来是如此简单

第一种场景,App中实现混编

  1. 创建桥接文件*.h

    新建一个桥接文件,New File 选择 Header File 创建
  2. 指定桥接文件

    project->targets->Build Setting->All->Swift Compilter General->Objective-C-Bridging-Header 指定刚刚的新建的桥接文件

    OC与Swift混编,三种场景的实现方式
  3. 导入OC头文件(*.h)到桥接文件

    如:#import "Log.h"

    OC与Swift混编,三种场景的实现方式
  4. 完成调用

    Swift文件中直接调用

注:在Swift项目中第一次创建OC文件,Xcode会自动提示创建桥接文件

OC与Swift混编,三种场景的实现方式

第二种场景,Framework 中实现混编

  1. 创建Famework

    创建完成后会生成一个同名头文件*.h
  2. 将OC头文件(*.h)设置为公开头文件

    project->targets->Build Phases->Headers->Public,直接拖入

    OC与Swift混编,三种场景的实现方式
  3. 导入OC头文件(*.h)到同名头文件

    如:#import "Log.h" OC与Swift混编,三种场景的实现方式
  4. 完成调用

    在对外的Swift文件中直接调用

    OC与Swift混编,三种场景的实现方式

    注:对外的类和方法必须 public 标示才可访问

第三种场景,Pod 包中实现混编

在完成第二种场景后,添加*.podspec文件实现 Pod 包

  1. 生成 *.podspec

    运行命令 pod spec create [name] 生成 *.podspec 文件

  2. 编辑 *.podspec

    在 *.podspec 中将OC头文件(*.h)设置为公开头文件

    如:spec.public_header_files = "Log.h"

     #完整的文件信息
    Pod::Spec.new do |spec|
    spec.name = "OCSwiftFramework"
    spec.version = "0.0.1"
    spec.summary = "OCSwiftFramework"
    spec.description = <<-DESC
    OCSWiftFramework
    DESC
    spec.homepage = "https://www.ichochy.com" spec.license = "MIT"
    # spec.license = { :type => "MIT", :file => "FILE_LICENSE" }
    spec.author = { "MLeo" => "iChochy@qq.com" } spec.platform = :osx
    spec.osx.deployment_target = "10.10" spec.source = { :git => "https://github.com/iChochy/HelloWorld.git", :tag => "#{spec.version}" } spec.source_files = "**/*.{h,m,swift}"
    spec.exclude_files = "Info.plist"
    spec.public_header_files = "Flog.h" spec.swift_version = "4.2"
    end
  3. 验证 *.podspec

    运行命令 pod lib lint 完成验证

  4. 完成调用

    a. 运行命令 pod trunk push [NAME.podspec] 完成发布

    b. Podfile 中添加 pod "[name]"

    c. 运行命令 pod install 完成 pod 安装

    d. 安装完成后直接调用

    注:可用 pod "[name]", :path => "[path]" 本地指定

GitHub:

HelloWorld:https://github.com/iChochy/HelloWorld.git


联系方式:

邮箱:iChochy@qq.com

网站:https://www.ichochy.com

源文:https://ichochy.com/posts/20190904/

上一篇:angular.bind


下一篇:js里function的apply vs. bind vs. call