UITableView, UIPickerView为什么要使用delegate模式

问题: I get that with delegates you are delegating a task to another object. I guess I just don't understand why this is beneficial.

最佳答案:

简而言之, UITableView专注通用功能的实现 -- 你不必考虑如何才能让table view滚动, 不必考虑记录数过多怎么办(怎么重用cell) 不必判断是哪个cell被点击了. UITableView会告诉你, 你只要老老实实的实现它指定的接口, 做一个合格的delegate, 实现与UI无关的业务逻辑就行了. UITableView和Delegate(通常是ViewController) 各司其职 --- 做一件事, 并把它做好.

原文如下:

[–]Eoghain 4 points 13 hours ago 

UITableView is the best example to think of here to get your head around it.

What does the UITableView do?

  • Display "cell" objects in a vertical stack
  • Scroll to allow displaying more cells than the visible area could hold
  • Reuse cells so that we don't run out of memory
  • Identify cells that are touched

And other things but that's a good place to start. Now you want to build an application that displays data in cells that can scroll on multiple pages without using delegates how would you create your own UITableView to be able to do this? I'm sure the basics above would be easy to implement and figure out, but what about these questions:

  • Would you pass in the cell object to draw?
  • And the data objects to fill out that cell, (array, dictionary, custom class)?
  • What if you needed to display more than 1 type of cell?
  • How would you deal with the action(s) to perform on a cell when it's tapped?
  • Do all cells perform the same action?

Is the version of UITableVIew that you are building even re-usable at this point? Not really, you'd have so much branching logic that your nice clean re-usable UITableView that just deals with laying things out on screen is a big buggy mess with no easy way to test it.

Now if you just focused only on the core features of what a UITableView does and instead delegated out the application logic to someone else you can see how clean and testable your UITableView becomes. All it cares about is putting some view it's given by someone else on screen at a specific location, allowing the views it's displaying to scroll, and telling whoever cares when a cell get's touched. This version of UITableView can be used by anyone for any purpose to display any data. It doesn't care what that data is, it doesn't care what happens when a cell is touched. It just delegates those decisions to someone else.

What delegates allow you to do is build re-usable code blocks that do "one" thing and do it well. They let the application logic be placed in less generic re-usable objects and allow developers to basically forget about all of the complexity of what the re-usable object is doing. How often do you concern yourself with the scrolling behavior of a UITableView? You don't, you know it'll work and do what it's told.

 

 

 

 

转载于:https://my.oschina.net/uniquejava/blog/686988

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值