在Android中點(diǎn)擊事件是以setOnclick的形式進(jìn)行設(shè)置的,用起來十分方便,而在ios中是以addTarget方式進(jìn)行的,每次設(shè)置點(diǎn)擊事件都需要聲明一個(gè)新的方法,在大部分情況下顯得未免有些麻煩。而且通常來說我們使用的最多的是TouchUpInside方式的點(diǎn)擊事件,所以為了方便使用,我對(duì)UIButton/UIView的點(diǎn)擊事件進(jìn)行了擴(kuò)展。
欽北網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)建站自2013年起到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
使用
和之前一樣,我們先來看看擴(kuò)展之后如何使用
oc版本
[_btn1 setOnclick:^{ NSLog(@"click btn1"); }];
swift版本
btn.setOnClick { print("click btn") }
用起來真的是非常簡單哈~
擴(kuò)展過程
接下來我們就來看看,到底是如何擴(kuò)展的呢?
oc版本
我們只需要為UIButton添加一個(gè)Category就可以使用了哦。
#import@interface UIButton(click) @property (nonatomic, strong) void (^clickBlock) (void); - (void) setOnclick : (void (^)(void))block; - (void) clickBtn : (UIButton*) sender; - (void) setTarget : action:(SEL)action; @end
#import "UIButton+click.h" #import@implementation UIButton(click) static void *clickKey = &clickKey; - (void)setClickBlock:(void (^)(void))clickBlock{ objc_setAssociatedObject(self, & clickKey, clickBlock, OBJC_ASSOCIATION_COPY); } - (void (^)(void))clickBlock{ return objc_getAssociatedObject(self, &clickKey); } -(void)setOnclick:(void (^)(void))block{ self.clickBlock = block; [self addTarget:self action:@selector(clickBtn:) forControlEvents:UIControlEventTouchUpInside]; } - (void) clickBtn : (UIButton*) sender{ self.clickBlock(); } @end
如果我們不希望每次都需要導(dǎo)入U(xiǎn)IButton+click.h,只需要將UIButton+click.h添加到pch文件中就可以了哦。
swift版本
相對(duì)來說swift版本就比較麻煩一點(diǎn),竟然不能直接擴(kuò)展閉包類型的屬性,所以最后多創(chuàng)建了一個(gè)UIClick對(duì)象。
class UIClick : Any{ var click : () -> Void = {return} } extension UIButton : Property{ var saveClick : UIClick{ get{ return get0() } set{ return set0(newValue) } } func setOnClick(click : @escaping () -> Void) { self.saveClick = UIClick() self.saveClick.click = click self.addTarget(self, action: #selector(btnClick), for: .touchUpInside) } @objc func btnClick(){ self.saveClick.click() } }
UIView onClick
看了以上的擴(kuò)展過程,相信大家對(duì)UIView onClick的擴(kuò)展心中也有數(shù)了,過程基本是一樣的,接下來只簡單寫一下不同的部分。
func setOnClickView(click : @escaping () -> Void) { self.isUserInteractionEnabled = true self.saveClickView = UIClick() self.saveClickView.click = click let tap = UITapGestureRecognizer(target: self, action: #selector(btnClickView)) tap.numberOfTapsRequired = 1 self.addGestureRecognizer(tap) }
oc的就略過了,原理是一樣的,代碼也是非常簡單。
總結(jié)
擴(kuò)展并不復(fù)雜,但是確實(shí)還是帶來了不少方便,希望這種擴(kuò)展思路能夠讓你眼前一亮,以上內(nèi)容有任何錯(cuò)誤歡迎指正。