ios协议和委托

时间:2024-08-31 21:03:44

在iPhone开发协议和委托是常接触到的东西,到底什么是协议什么是委托,他们什么关系?

一 协议

(1)协议相当于没有与类相关联的接口,他申明一组方法,列出他的参数和返回值,共享给其他类使用,然后不进行实现,让用它的类来实现这些方法

(2)在任何一个类中,只有声明了协议,都可以实现协议里的方法。

(3)协议不是一个类,更没有父类了。

(3)协议里面的方法经常都是一些委托方法,

二 委托

委托,故名思议就是托别人办事。打个比方:

张三迫切需要一分工作,但是不知道去哪找。于是他就拜托(委托)李四给帮找一份合适工作,但是托人办事得给被人好处啊,于是张三给李四塞了一个红包(协议),于是李四通过自己关系在某公司找了一份文秘的工作(实现协议里面委托方法),于然后他把文秘这份工作给了张三,张三就找到工作了;

三 我们来看一个比较常用的表格单元实现委托和协议

UITableViewDataSource协议和他的委托方法

  1. @protocol UITableViewDataSource<NSObject>
  2. @required
  3. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section;
  4. // Row display. Implementers should *always* try to reuse cells by setting each cell's reuseIdentifier and querying for available reusable cells with dequeueReusableCellWithIdentifier:
  5. // Cell gets various attributes set automatically based on table (separators) and data source (accessory views, editing controls)
  6. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;
  7. @optional
  8. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;              // Default is 1 if not implemented
  9. - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section;    // fixed font style. use custom view (UILabel) if you want something different
  10. - (NSString *)tableView:(UITableView *)tableView titleForFooterInSection:(NSInteger)section;
  11. // Editing
  12. // Individual rows can opt out of having the -editing property set for them. If not implemented, all rows are assumed to be editable.
  13. - (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath;
  14. // Moving/reordering
  15. // Allows the reorder accessory view to optionally be shown for a particular row. By default, the reorder control will be shown only if the datasource implements -tableView:moveRowAtIndexPath:toIndexPath:
  16. - (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath;
  17. // Index
  18. - (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView;                                                    // return list of section titles to display in section index view (e.g. "ABCD...Z#")
  19. - (NSInteger)tableView:(UITableView *)tableView sectionForSectionIndexTitle:(NSString *)title atIndex:(NSInteger)index;  // tell table which section corresponds to section title/index (e.g. "B",1))
  20. // Data manipulation - insert and delete support
  21. // After a row has the minus or plus button invoked (based on the UITableViewCellEditingStyle for the cell), the dataSource must commit the change
  22. - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath;
  23. // Data manipulation - reorder / moving support
  24. - (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath;
  25. @end

这是一个完整协议定义

@protocol  协议名

声明方法

@end

但是我们还看到两个特殊关键字 @required  和 @optional

@required 表示我们用到这个协议的时候必须实现这个协议的方法

@optional 表示我们可选择性实现这些方法,看那个需要我们就去实现,不需要的就不实现

UITableViewDelegate协议和委托方法

  1. @protocol UITableViewDelegate<NSObject, UIScrollViewDelegate>
  2. @optional
  3. // Display customization
  4. - (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath;
  5. // Variable height support
  6. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
  7. - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section;
  8. - (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section;
  9. // Section header & footer information. Views are preferred over title should you decide to provide both
  10. - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section;   // custom view for header. will be adjusted to default or specified header height
  11. - (UIView *)tableView:(UITableView *)tableView viewForFooterInSection:(NSInteger)section;   // custom view for footer. will be adjusted to default or specified footer height
  12. // Accessories (disclosures).
  13. - (UITableViewCellAccessoryType)tableView:(UITableView *)tableView accessoryTypeForRowWithIndexPath:(NSIndexPath *)indexPath __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_NA,__MAC_NA,__IPHONE_2_0,__IPHONE_3_0);
  14. - (void)tableView:(UITableView *)tableView accessoryButtonTappedForRowWithIndexPath:(NSIndexPath *)indexPath;
  15. // Selection
  16. // Called before the user changes the selection. Return a new indexPath, or nil, to change the proposed selection.
  17. - (NSIndexPath *)tableView:(UITableView *)tableView willSelectRowAtIndexPath:(NSIndexPath *)indexPath;
  18. - (NSIndexPath *)tableView:(UITableView *)tableView willDeselectRowAtIndexPath:(NSIndexPath *)indexPath __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_3_0);
  19. // Called after the user changes the selection.
  20. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;
  21. - (void)tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_3_0);
  22. // Editing
  23. // Allows customization of the editingStyle for a particular cell located at 'indexPath'. If not implemented, all editable cells will have UITableViewCellEditingStyleDelete set for them when the table has editing property set to YES.
  24. - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath;
  25. - (NSString *)tableView:(UITableView *)tableView titleForDeleteConfirmationButtonForRowAtIndexPath:(NSIndexPath *)indexPath __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_3_0);
  26. // Controls whether the background is indented while editing.  If not implemented, the default is YES.  This is unrelated to the indentation level below.  This method only applies to grouped style table views.
  27. - (BOOL)tableView:(UITableView *)tableView shouldIndentWhileEditingRowAtIndexPath:(NSIndexPath *)indexPath;
  28. // The willBegin/didEnd methods are called whenever the 'editing' property is automatically changed by the table (allowing insert/delete/move). This is done by a swipe activating a single row
  29. - (void)tableView:(UITableView*)tableView willBeginEditingRowAtIndexPath:(NSIndexPath *)indexPath;
  30. - (void)tableView:(UITableView*)tableView didEndEditingRowAtIndexPath:(NSIndexPath *)indexPath;
  31. // Moving/reordering
  32. // Allows customization of the target row for a particular row as it is being moved/reordered
  33. - (NSIndexPath *)tableView:(UITableView *)tableView targetIndexPathForMoveFromRowAtIndexPath:(NSIndexPath *)sourceIndexPath toProposedIndexPath:(NSIndexPath *)proposedDestinationIndexPath;
  34. // Indentation
  35. - (NSInteger)tableView:(UITableView *)tableView indentationLevelForRowAtIndexPath:(NSIndexPath *)indexPath; // return 'depth' of row for hierarchies
  36. // Copy/Paste.  All three methods must be implemented by the delegate.
  37. - (BOOL)tableView:(UITableView *)tableView shouldShowMenuForRowAtIndexPath:(NSIndexPath *)indexPath __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_5_0);
  38. - (BOOL)tableView:(UITableView *)tableView canPerformAction:(SEL)action forRowAtIndexPath:(NSIndexPath *)indexPath withSender:(id)sender __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_5_0);
  39. - (void)tableView:(UITableView *)tableView performAction:(SEL)action forRowAtIndexPath:(NSIndexPath *)indexPath withSender:(id)sender __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_5_0);
  40. @end

在用的时候,我们现在声明协议

  1. #import <UIKit/UIKit.h>
  2. @interface BIDViewController : UIViewController <UITableViewDataSource, UITableViewDelegate>
  3. @property (strong, nonatomic) NSDictionary *names;
  4. @property (strong, nonatomic) NSArray *keys;
  5. @end

实现UITableViewDataSource  UITableViewDelegate协议里面的委托方法

  1. #pragma mark -
  2. #pragma mark Table View Data Source Methods
  3. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
  4. return [keys count];
  5. }
  6. - (NSInteger)tableView:(UITableView *)tableView
  7. numberOfRowsInSection:(NSInteger)section {
  8. NSString *key = [keys objectAtIndex:section];
  9. NSArray *nameSection = [names objectForKey:key];
  10. return [nameSection count];
  11. }
  12. - (UITableViewCell *)tableView:(UITableView *)tableView
  13. cellForRowAtIndexPath:(NSIndexPath *)indexPath {
  14. NSUInteger section = [indexPath section];
  15. NSUInteger row = [indexPath row];
  16. NSString *key = [keys objectAtIndex:section];
  17. NSArray *nameSection = [names objectForKey:key];
  18. static NSString *SectionsTableIdentifier = @"SectionsTableIdentifier";
  19. UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:
  20. SectionsTableIdentifier];
  21. if (cell == nil) {
  22. cell = [[UITableViewCell alloc]
  23. initWithStyle:UITableViewCellStyleDefault
  24. reuseIdentifier:SectionsTableIdentifier];
  25. }
  26. cell.textLabel.text = [nameSection objectAtIndex:row];
  27. return cell;
  28. }
  29. - (NSString *)tableView:(UITableView *)tableView
  30. titleForHeaderInSection:(NSInteger)section {
  31. NSString *key = [keys objectAtIndex:section];
  32. return key;
  33. }
  34. - (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
  35. return keys;
  36. }

这就就是实现一些里面的委托方法过程运行改程序运行结果

ios协议和委托  ios协议和委托

该程序源码http://download.****.net/detail/duxinfeng2010/4695666