IOS UITableViewCell詳解及按鈕點(diǎn)擊事件處理實(shí)例
IOS UITableViewCell詳解及按鈕點(diǎn)擊事件處理
今天突然做項(xiàng)目的時(shí)候,又遇到處理自定義的UITableViewCell上按鈕的點(diǎn)擊事件問(wèn)題。我知道有兩種方式,可是突然想不起來(lái)之前是怎么做的了,好記性不如爛筆頭,還是記錄一下吧。
1、第一種方式給Button加上tag值
這里分為兩種:一種是直接在原生的UITableViewCell上添加UIButton按鈕,然后給UIButton設(shè)置tag值,然后在控制器里的方法里通過(guò)取數(shù)據(jù),做界面跳轉(zhuǎn)等。還是舉個(gè)例子吧,省的回憶半天。
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { static NSString *identifier = @"Cell"; UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:reuseIdentifier]; if (cell == nil) { cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier]; cell.selectionStyle = UITableViewCellSelectionStyleNone; } User *user = _users[indexPath.row]; cell.user = user; //拍照button UIButton *photographButton = [UIButton buttonWithType:UIButtonTypeCustom]; photographButton.frame = CGRectMake(221 , 10, 100, 44); [photographButton setImage:[UIImage imageNamed:@"camera.png"] forState:UIControlStateNormal]; [photographButton addTarget:self action:@selector(photographButtonClicked:) forControlEvents:UIControlEventTouchUpInside]; photographButton.tag = indexPath.row; [cell.contentView addSubview:photographButton]; return cell; }
然后在點(diǎn)擊事件中取數(shù)據(jù),加信息
- (void)photographButtonClicked:(UIButton *)sender{ User *user = _users[sender.tag]; PhotoPickerController *photoPicker = [[PhotoPickerController alloc] init]; photoPicker.user = user; [self.navigationController pushViewController:photoPicker animated:YES]; }
以上兩個(gè)方法都是在同一個(gè)控制器中。
2、自定義了UITableViewCell,那么就在UITableViewCell里添加一個(gè)代理方法。
#import <UIKit/UIKit.h> @protocol TermCellDelegate <NSObject> - (void)choseTerm:(UIButton *)button; @end @interface TermCell : UITableViewCell @property (retain, nonatomic) IBOutlet UIButton *checkButton; @property (retain, nonatomic) IBOutlet UILabel *termLabel; @property (assign, nonatomic) BOOL isChecked; @property (assign, nonatomic) id<TermCellDelegate> delegate; - (IBAction)checkAction:(UIButton *)sender; @end #import "TermCell.h" @implementation TermCell - (void)awakeFromNib { // Initialization code } - (void)setSelected:(BOOL)selected animated:(BOOL)animated { [super setSelected:selected animated:animated]; // Configure the view for the selected state } - (void)layoutSubviews { [super layoutSubviews]; if (_isChecked) { [_checkButton setBackgroundImage:[UIImage imageNamed:@"task_state_checked"] forState:UIControlStateNormal]; } else { [_checkButton setBackgroundImage:[UIImage imageNamed:@"task_state_unchecked"] forState:UIControlStateNormal]; } } - (void)dealloc { [_checkButton release]; [_termLabel release]; [super dealloc]; } - (IBAction)checkAction:(UIButton *)sender { if ([_delegate respondsToSelector:@selector(choseTerm:)]) { sender.tag = self.tag; [_delegate choseTerm:sender]; } } @end
然后再控制器中實(shí)現(xiàn)Cell的代理方法即可
#pragma mark - TermCellDelegate - (void)choseTerm:(UIButton *)button { _clickIndex = button.tag; UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"確定修改學(xué)期嗎?" message:nil delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"確定", nil nil]; [alertView show]; }
當(dāng)然,這里也可以做界面跳轉(zhuǎn),取數(shù)據(jù)依然用button的tag值。
補(bǔ)充:這里還可以在代理方法中將cell本身傳回去,這樣不用從數(shù)組取數(shù)據(jù),直接利用cell的數(shù)據(jù)對(duì)象,更簡(jiǎn)單吆。
3、是直接在自定義的Cell里面跳轉(zhuǎn),這種耦合性比較強(qiáng)。思路先是找到button的父控制器,然后做界面跳轉(zhuǎn)或者其他操作。有這樣一個(gè)工具方法
#import "UIView+Additions.h" @implementation UIView (Additions) - (UIViewController *)viewController { UIResponder *next = [self nextResponder]; do { if ([next isKindOfClass:[UIViewController class]]) { return (UIViewController *)next; } next = [next nextResponder]; } while (next != nil); return nil; }
頭文件就不寫(xiě)了,很簡(jiǎn)單的擴(kuò)展。
- (void)setWeiboModel:(WeiboModel *)weiboModel { if (_weiboModel != weiboModel) { [_weiboModel release]; _weiboModel = [weiboModel retain]; } __block WeiboCell *this = self; _userImage.touchBlock = ^{ NSString *nickName = this.weiboModel.user.screen_name; UserViewController *userCtrl = [[UserViewController alloc] init]; userCtrl.userName = nickName; [this.viewController.navigationController pushViewController:userCtrl animated:YES]; [userCtrl release]; }; }
這里是給Cell賦值model,然后點(diǎn)擊事件是用Block實(shí)現(xiàn)的。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
UITableView中Cell重用機(jī)制導(dǎo)致內(nèi)容重復(fù)的解決方法
這篇文章主要為大家詳細(xì)介紹了UITableView中Cell重用機(jī)制導(dǎo)致內(nèi)容重復(fù)的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06ios使用OC寫(xiě)算法之遞歸實(shí)現(xiàn)八皇后
本篇文章主要介紹了ios使用OC寫(xiě)算法之遞歸實(shí)現(xiàn)八皇后,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08詳解iOS的Core Animation框架中的CATransform3D圖形變換
CATransform3D一般用于操作view的layer的,是Core Animation的結(jié)構(gòu)體,可以用來(lái)做比較復(fù)雜的3D操作,這里我們就帶大家來(lái)詳解iOS的Core Animation框架中的CATransform3D圖形變換2016-07-07iOS在頁(yè)面銷(xiāo)毀時(shí)如何優(yōu)雅的cancel網(wǎng)絡(luò)請(qǐng)求詳解
這篇文章主要給大家介紹了關(guān)于iOS在頁(yè)面銷(xiāo)毀時(shí)如何優(yōu)雅的cancel網(wǎng)絡(luò)請(qǐng)求的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05iOS Xcode自定義代碼塊及遷移的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于iOS Xcode自定義代碼塊及遷移的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用iOS Xcode具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04