1、创建桥接文件
- 在创建另一种言语的文件时XCode会提示创建
项目名-Bridging-Header.h
的桥接文件
2、Swift调用OC
- 创建OC文件
#import "MyViewController.h" @interface MyViewController () @end @implementation MyViewController - (void)viewDidLoad { [super viewDidLoad]; self.title = @"OC"; self.view.backgroundColor = UIColor.cyanColor; UILabel *lbl = [UILabel new]; lbl.text = @"OC的标签"; lbl.backgroundColor = UIColor.redColor; lbl.frame = CGRectMake(100, 100, 150, 50); [self.view addSubview:lbl]; }
- 桥接文件:项目名-Bridging-Header.h 文件中要将想要运用的 OC的.h文件导入
#import "MyViewController.h"
- 在Swift文件中调用
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. title = "Swift" view.backgroundColor = .white let btn = UIButton(type: .custom) btn.frame = CGRect(x: 150, y: 150, width: 150, height: 100) btn.setTitle("点击跳转", for: .normal) btn.backgroundColor = .green view.addSubview(btn) btn.addTarget(self, action: #selector(didClickBtn), for: UIControl.Event.touchUpInside) } @objc func didClickBtn() { let myVC = MyViewController() navigationController?.pushViewController(myVC, animated: true) } }
- Button履行的办法要用 @objc 修饰
NS_SWIFT_NAME
、NS_SWIFT_UNAVAILABLE
-
NS_SWIFT_NAME(替换名):
重命名在Swift中的称号
,可用来进行办法名躲藏 - NS_SWIFT_UNAVAILABLE(_msg):Swift中不行见,不能运用
// OC的MyViewController.h文件
#import <UIKit/UIKit.h>
NS_ASSUME_NONNULL_BEGIN
@interface MyViewController : UIViewController
// 将method1办法在Swift中替换成swiftMethod()办法
- (void)method1 NS_SWIFT_NAME(swiftMethd());
// 将method2办法再Swift中躲藏
- (void)method2 NS_SWIFT_UNAVAILABLE("Swift中该办法不行调用");
@end
NS_ASSUME_NONNULL_END
class ViewController: UIViewController {
override func viewDidLoad() {
......
}
@objc func didClickBtn() {
let myVC = MyViewController()
// 在Swift中找不到OC的method1与method2办法,只要一个改了名的swiftMethod办法
myVC.swiftMethod()
navigationController?.pushViewController(myVC, animated: true)
}
}
NS_REFINED_FOR_SWIFT
- 在Swift中调用OC的接口有时发现并不契合Swift的语法标准或者运用起来会比较别扭,这个时候可以运用NS_REFINED_FOR_SWIFT宏界说 来对OC的接口进行晋级改造
规矩
-
NS_REFINED_FOR_SWIFT 可用于办法和特点,添加了 NS_REFINED_FOR_SWIFT 的 Objective-C API 在导入到 Swift 时,详细的 API 重命名规矩如下:
-
关于 初始化办法,在其
第一个参数标签前面加 "__"
// Objective-C API - (instancetype)initWithClassName:(NSString *)name NS_REFINED_FOR_SWIFT; // In Swift init(__className: String)
-
关于 其它办法,在其
基名前面加 "__"
// Objective-C API - (NSString *)displayNameForMode:(DisplayMode)mode NS_REFINED_FOR_SWIFT; // In Swift func __displayNameForMode(mode: DisplayMode) -> String
-
下标办法将被视为任何其它办法,在办法名前面加 “__”(而不是作为 Swift 下标导入)
-
其他声明将在其称号前加上 "__"
,例如特点// Objective-C API @property DisplayMode mode NS_REFINED_FOR_SWIFT; // In Swift var __mode: DisplayMode { get set }
注意:
NS_REFINED_FOR_SWIFT
和NS_SWIFT_NAME
一重用的话,NS_REFINED_FOR_SWIFT
不收效,而是以NS_SWIFT_NAME
指定的称号重命名 Objective-C API
3、OC调用Swift
- 创建Swift文件
import Foundation // 有必要承继于 NSObject class Person: NSObject { // 想公开给OC的要运用 @objc 修饰 @objc var name: String @objc var age : Int @objc init(name: String, age: Int) { self.name = name self.age = age } }
-
有必要承继于 NSObject
,类、结构体等才会公开给OC -
有必要运用 @objc 修饰
,特点、办法等才会公开给OC
-
- 在OC文件中引入
项目名-Swift.h
文件,然后运用Swift内容#import "MyViewController.h" #import "SwiftAndOC-Swift.h" @interface MyViewController () @end @implementation MyViewController - (void)viewDidLoad { [super viewDidLoad]; Person *p = [[Person alloc] initWithName:@"LZ" age:18]; NSLog(@"%@",p.name); }