天天看点

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

  今天就结合两个实例来窥探一下swift中的协议与delegate回调(委托代理回调)。本篇先给出cocoatouch中常用控件uitableview的常用回调,并以此来认识一下回调的使用方式。紧接着会给出如何去实现自己的delegate回调,即在自定义控件中去实现委托代理回调。言归正传,开始今天的博客主题。

  一.从uitableview中来窥探协议的委托代理回调

    uitableview这个高级控件在ios开发中的出镜率是比较高的,今天的重点不是介绍如何使用uitableview, 而是让通过uitableview的工作方式来直观的感受一下协议的使用场景,以及delegate代理的工作方式。如果你对uitableview控件不熟的话,完全可以跳过这一部分,直接进入第二部分。如果你要更好的理解delegate委托回调,还是很有必要看这一部分的。

    下面就先以uitableview的uitableviewdatasource协议来看一下委托代理的使用方式。为了简化代码呢,下面的tableview的使用就没有实现uitableviewdelegate协议还是那句话,今天的重点是protocol和delegate, 而不是如何使用uitableview。下方的截图就是我们要使用uitableview和uitableviewdatasource来做的事情。当然下方的实例无论是代码还是布局方面还是灰常简单的,运行效果如下所示。

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

    上面的cell中就是一个imageview和一个label, 布局灰常简单啦,接下来就简单介绍一下在swift中是如何实现(说白了,和objc实现起来大同小异)。还是结合着storyboard来做吧,毕竟使用storyboard布局更为简单一些。

    1. 使用storyboard来布局控件,控件布局如下:

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

    2. 给上述cell绑定相应的swift源码,并关联imageview和label, 相应cell(beautifulgrillcell)的代码如下所示。girlimageview即为做吧的图片,

girlnamelable为图片右边的文字。

    3.接下来就是要模拟我们在tableview上显示的数据了,在正常开放中这些数据往往来源于网络请求,而在本篇博客中就模拟数据源,来为我们的tableview提供显示的数据。数据源的格式是一个数组,而数组中存放的是多个字典,每个字典有两个键值对,一个键值对存储要显示图片的文件名,另一个键值对则存储美女的名字。为了使该数据的存储结构,请看下方结构图。

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

    原理图有了,接下来就要使用代码来创建出上述结构的数据以供tableview的数据源使用,下面的方法就是实现上述结构的函数。

       (1) 首先我们要在视图控制器相应的类中添加一个可变数组,用来存放数据,如下所示:

      (2) 接着就是往上面这个数组中填充数据了,代码如下:

    4. 我们上面storyboard中的视图控制器使用的是uiviewcontroller而不是uitableviewcontroller。 我们在uiviewcontroller上贴了一层uitableview, 所以我们需要在相应的viewcontroller对应的swift源码中进行uitableview的绑定,并实现uitableviewdatasource代理,并为uitableview指定该代理。下方的代码就是关联tableview并指定代理方法。代码如下:

    4. 对mytableview的datasource(数据提供者)指定完代理对象后,接下来就是要实现uitableviewdatasource中的相应的方法了,viewcontroller通过这些协议委托回调的代理方法来为tableview提供数据。下方是uitableviewdatasource委托方法中返回tableview的section个数的回调方法,如下所示:

    5.上面回调方法是返回section个数的,紧接着下方就是返回每个section中cell个数的回调方法。cell的个数就是数组datasource中元素的个数。

    6. 下面这个方法是比较重要的,下方的方法,就是返回每行的cell的委托回调方法。通过cell的重用标示符来创建cell的实例对象,并对cell上的一些属性赋值,并返回当前是cell实例对象,代码如下所示。

经过上面这些步骤,你就可以去实现博客最上方截图中的效果了,上面主要用到的还是tableview的uitableviewdatasource委托代理, 使用方法如上。上面使用的委托回调主要是使用swift中的协议(protocol)来实现的。那么如何使用协议来实现你自己的委托回调呢?这将是下面将要介绍的内容。

  二. 认识协议,并使用协议实现委托回调

    接下来的内容就要介绍如何使用协议来定义属于你自己的委托代理回调(delegate)了。第二部分还是以实例为准,在上面的demo中加入我们自己定义的委托代理回调。我们需要做的就是,在上面界面中,我们点击任意cell就可以push(导航控制器展示视图控制器的一种方式,可以理解为视图控制器压栈的过程)到一个viewcontroller中,这个viewcontroller要做的事情就是输入美女的名字,点击返回后通过自己定义的委托回调,把你输入的值回调到上一个页面(tableview)中去,并修改相应cell上的名字。说白了,就是对美女的名字做一个修改。

    如果上面的文字让你迷惑的话,那么接下来看实例好了,该实例还算是简单的。下方是实例的操作步骤,如下所示:

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

    1.实现编辑美女姓名的页面

      (1) 在storyboard上新添加一个视图控制器(uiviewcontroller), 并命名为editviewcontroller,给视图控制器就是上方截图中绿色的那个视图控制器,主要用来对美女姓名 修改,并通过委托回调把值传给上个页面。该视图控制器的页面布局比较简单,具体如下所示:

窥探Swift之协议(Protocol)和委托代理(Delegate)回调的使用

      (2)ui就如数所示,为editviewcontroller关联editviewcontroller.swift源文件后,再对其上面的使用到的控件进行关联即可。紧接着我们要实现一个协议,这个协议我们用来所委托回调使用。这个协议可以定义在editviewcontroller.swift源文件中。在协议定义之前,先对什么是协议简单的提上一嘴。先简单的理解,协议中的方法只有声明,没有实现,并且使用protocol关键自进行声明,下方的代码就是我们要使用的协议。协议中有一个fetchgirlname(name:string)的方法,用来回调出输入的数值。默认方法是必选的,你可以使用optional关键字使方法可选,在此就不做过多赘述了。

      (3) 接着要实现editviewcontroller类中的东西了,代码如下。

        成员变量var girloldname:string?负责接收上个页面传过来的美女的姓名。weak var delegate:editviewcontrollerdelegate? 这个声明为weak的delegate成员变量则是必须要实现editviewcontrollerdelegate协议的委托代理者,使用weak修饰为了避免强引用循环。接着是girlnametextfield就是关联的输入框了,负责接收用户输入,把值交付给委托代理者。

        在viewwilldisappear方法中,会将用户输入的值交付给委托代理者的fetchgirlname方法。deinit是析构函数,用来观察是否引起强引用循环,因为我们是使用的weak, 所以不会引起强引用循环,该deinit方法当返回时,是会被释放掉的。

    2.上面的代码是实现编辑页面并实现相应的委托协议,下方就是要从之前tableview中进行跳转。也就是点击tableview的每一行,然后跳转到编辑页面对其当前点击的cell进行编辑,编辑后返回通过代理进行值的修改。

      (1)首先要解决的就是点击cell跳转到editviewcontroller, 要执行这个事件,我们还必须实现tableview的另一个协议,就是uitableviewdelegate, 以为点击cell的事件获取的方法就在tableviewdelegate中。所以我们要在tableview所在的viewcontroller中的viewdidload()中指定uitableviewdelegate的委托代理者。如下所示。同时该viewcontoller也要实现uitableviewdelegate协议。

    

      (2) 实现uitableviewdelegate协议中点击cell的方法,方法中的内容如下所示。在该方法中,首先我们要暂存一下点击的是哪个cell, 也就是记录一下点击cell的indexpath, 然后就是获取点击的cell对象,因为通过该cell对象,可以获取相应cell上的数据。具体的不多说了,请看代码中的注释。

      (3)上面是跳转,接下来就是要实现editviewcontrollerdelegate中的回调方法,来处理相应的回调参数了。下方就是在表视图中实现的回调方法,具体请看代码中的注释:

  

    经过上面的步骤,我们就可以去定义属于自己的协议,并在此协议上实现委托回调了。上面的场景在ios开发中极为常见,使用场景也是比较广泛的。所以协议无论在swift还是在ios开发中都是极为重要的概念之一。好今天的博客内容也挺多的了,就到此为止,剩下的东西,会在以后的博客中继续更新。