在Android中点击事件是以setOnclick的形式进行设置的,用起来十分方便,而在ios中是以addTarget方式进行的,每次设置点击事件都需要声明一个新的方法,在大部分情况下显得未免有些麻烦。而且通常来说我们使用的最多的是TouchUpInside方式的点击事件,所以为了方便使用,我对UIButton/UIView的点击事件进行了扩展。
使用
和之前一样,我们先来看看扩展之后如何使用
oc版本
[_btn1 setOnclick:^{ NSLog(@"click btn1"); }];
swift版本
btn.setOnClick { print("click btn") }
用起来真的是非常简单哈~
扩展过程
接下来我们就来看看,到底是如何扩展的呢?
oc版本
我们只需要为UIButton添加一个Category就可以使用了哦。
#import <UIKit/UIKit.h> @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 <objc/runtime.h> @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
如果我们不希望每次都需要导入UIButton+click.h,只需要将UIButton+click.h添加到pch文件中就可以了哦。
swift版本
相对来说swift版本就比较麻烦一点,竟然不能直接扩展闭包类型的属性,所以最后多创建了一个UIClick对象。
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
看了以上的扩展过程,相信大家对UIView onClick的扩展心中也有数了,过程基本是一样的,接下来只简单写一下不同的部分。
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的就略过了,原理是一样的,代码也是非常简单。
总结
扩展并不复杂,但是确实还是带来了不少方便,希望这种扩展思路能够让你眼前一亮,以上内容有任何错误欢迎指正。
问题内容: 我有一个id为id的按钮。我将此元素附加了两个jQuery事件 1。 2。 但是每次它给我 问题答案: 您需要使用超时来检查第一次点击后是否还有另一次点击。 这是窍门: 用法:
问题内容: 我试图区分OnClick函数中的左键单击和右键单击。但, 证明e 。对于合成事件未定义。如何在此处区分左键和右键? 问题答案: 您也可以这样做。同时拥有onClick和onContextMenu处理程序 您可以根据其他答案的建议进行检查,也可以进行检查。(此外,如果右键单击,请阻止默认设置。) 使用 使用 这是一个演示 http://jsbin.com/seyeliv/edit?htm
本文向大家介绍js a标签点击事件,包括了js a标签点击事件的使用技巧和注意事项,需要的朋友参考一下 当我们在处理a标签上的点击事件时发现即使href=""里面为空,点击事件的效果也不明显,这种情况该如何处理呢?常见的处理方法有以下几种: 1.a href="javascript:void(0);" rel="external nofollow" onclick="method()" 这种方法是
我刚刚开始使用Chart.js,我很快就变得非常沮丧。我有我的堆叠条形图工作,但是我不能让点击“事件”工作。 我在图表中找到了对GitHub的评论。js声明使用函数<code>getBarsAtEvent 我在画布元素上设置了一个事件监听器(正确的方式): ...然而在我的< code>handleClick函数中,< code > chart . getbarsatevent 是未定义的! 现在
2.url点击事件的监听 url点击事件的监听是指将访客和客服发送在聊窗中的链接ur的点击事件暴漏出来,用户可以自定义url打开方式(默认使用SDK内置Webview加载)。监听接口为OnUrlClickListener; 注册监听方法: Ntalker.getInstance().setOnUrlClickListener(OnUrlClickListener onMsgClickListene
本文向大家介绍javascript/jquery实现点击触发事件的方法分析,包括了javascript/jquery实现点击触发事件的方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript/jquery实现点击触发事件的方法。分享给大家供大家参考,具体如下: 点击事件 原声态 和 jquery 感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具