加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

《从零开始学Swift》学习笔记(Day 65)――Cocoa Touch设计模式

发布时间:2020-12-14 07:11:25 所属栏目:百科 来源:网络整理
导读:原创文章,欢迎转载。转载请注明:关东升的博客 实现目标与动作关联使用 UIControl 类 addTarget(_:action:forControlEvents:) 方法,示例代码如下: button.addTarget(self,action:"onClick:",forControlEvents:UIControlEvents.TouchUpInside) 其中的 acti

原创文章,欢迎转载。转载请注明:关东升的博客

实现目标与动作关联使用UIControladdTarget(_:action:forControlEvents:)方法,示例代码如下:

button.addTarget(self,action:"onClick:",forControlEvents:UIControlEvents.TouchUpInside)


其中的action参数"onClick:"事实上就是选择器(Selector)。

问题提出

任何能够将方法调用的绑定推迟到运行期,在编译时方法调用者不需要知道要调用的方法是什么,这个可以降低调用者与被调用者之间的耦合度,这样就语言就很灵活。在C语言在提供一种函数指针技术,Objective-CSwift语言都提供选择器(Selector)类型,它是C语言函数指针的面向对象替代技术。

选择器在CocoaCocoa Touch中的目标动作、通知和委托等模式中方法的调用实现的关键。

解决方案

Objective-C中选择器是SEL数据类型,使用@selector()语句调用,调用onClick:方法的Objective-C示例代码如下:

SELselector=@selector(onClick:);
[buttonaddTarget:selfaction:selector
forControlEvents:UIControlEventTouchUpInside];


Swift中虽然没有提供SEL数据类型,而是提供了Selector结构体,通过方法名字符串构建Selector实例,示例代码如下:

button.addTarget(self,action:Selector("onClick:"),forControlEvents:UIControlEvents.TouchUpInside)


通过选择器调用方法,关键是方法名字,它有一定规律的。穷其根本是源自于Objective-C多重参数方法命名规律。方法名的冒号暗示了方法名应该具有几个参数,下面我们看几个示例:

//选择器为"onClick:"
funconClick(sender:AnyObject){
NSLog("onClick:")
}

//选择器为"onClick:forEvent:"
funconClick(sender:AnyObject,forEventevent:UIEvent){
NSLog("onClick:forEvent:")
}

//选择器为"onClickWithExtSender:forEvent:"
funconClick(extSendersender:AnyObject,forEventevent:UIEvent){
NSLog("onClickWithExtSender:forEvent:")
}


出于数据封装的需要,我们会在方法前面加private,使其变为私有方法,代码如下。

privatefunconClick(sender:AnyObject){
NSLog("onClick:")
}


但是这样方法在调用时候会出现如下错误:

unrecognizedselectorsenttoinstance0x7f7f81499b10'


这个错误的意思是没有找到选择器所指定的方法,也就是没有找到onClick:方法。正确的做法是在方法前面添加@objc属性注释,这说明选择器是在objc runtime运行环境下调用的。

//选择器为"onClick:"
@objcprivatefunconClick(sender:AnyObject){
NSLog("onClick:")
}


欢迎关注关东升新浪微博@tony_关东升。
关注智捷课堂微信公共平台,了解最新技术文章、图书、教程信息

wKioL1beULKTkydqAADC6S3kNXs503.jpg


更多精品iOSCocos、移动设计课程请关注智捷课堂官方网站:http://www.zhijieketang.com
智捷课堂论坛网站:http://51work6.com/forum.php

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读