配置如下:
Xcode 8.2
Swift 3.0
在iOS開發(fā)中,無論是 Objective-C 還是 Swift ,Delegate 有著具足輕重的位置,如TabelViewDelegate 與 TableViewDataSource。
Swift 中的代理模式 和 Objective-C 除了語法外,幾乎一樣。
Objective-C 代理模式
在介紹 Swift 代理模式前,先來看回顧一下 Objective-C 中的代理模式如何實(shí)現(xiàn)
Objective-C 中用代理實(shí)現(xiàn)反向傳值:

委托方(子控制器)
委托方需要實(shí)現(xiàn)
創(chuàng)建協(xié)議 、聲明協(xié)議方法
@protocol SubViewDelegate <NSObject> - (void)backWithStr:(NSString *) str; @end
創(chuàng)建一個(gè)代理屬性
// weak聲明 @property (nonatomic, weak) id<SubViewDelegate> delegate;
執(zhí)行協(xié)議方法
// 判斷代理是實(shí)現(xiàn)該方法,避免carsh if ([self.delegate respondsToSelector:@selector(backWithStr:)]) { [self.delegate backWithStr:self.textField.text]; }代理方(主控制器)
代理方需要實(shí)現(xiàn)
遵守(繼承)協(xié)議
@interface ViewController () <SubViewDelegate>
將代理設(shè)為自己
subVC.delegate = self;
實(shí)現(xiàn)代理方法
- (void)backWithStr:(NSString *)str { self.label.text = str; }Swift 代理模式
Swift 代理模式 與 Objective-C 一樣,只是語法不同。
Swift 中用代理實(shí)現(xiàn)反向傳值:

委托方(子控制器)
創(chuàng)建協(xié)議 、聲明協(xié)議方法
protocol SubViewDelegate { func backStr(str: String) } 創(chuàng)建一個(gè)代理屬性
var delegate: SubViewDelegate?
執(zhí)行協(xié)議方法
/// 執(zhí)行代理方法,將值回傳 delegate?.backStr(str: textField.text ?? "")
代理方(主控制器)
繼承協(xié)議
class ViewController: UIViewController, SubViewDelegate
將代理設(shè)為自己
subVC.delegate = self
實(shí)現(xiàn)代理方法
func backStr(str: String) { self.textF.text = str }總結(jié)
對(duì)比可以方法 Swift 代理模式 與 Objective-C 用法完全相同,只是語法發(fā)生了變化。
值得一提的是Swift 的擴(kuò)展 extension可以用來繼承協(xié)議,實(shí)現(xiàn)代碼隔離,便于維護(hù)。
/// 使用擴(kuò)展繼承協(xié)議 實(shí)現(xiàn)協(xié)議方法 可以分離代碼extension ViewController: SubViewDelegate{ /// 實(shí)現(xiàn)代理方法 func backStr(str: String) { self.textF.text = str }}最后附上Demo源碼
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)VEVB武林網(wǎng)的支持。
新聞熱點(diǎn)
疑難解答
圖片精選