当前位置: 移动技术网 > IT编程>移动开发>IOS > IOS UITableViewCell详解及按钮点击事件处理实例

IOS UITableViewCell详解及按钮点击事件处理实例

2019年07月24日  | 移动技术网IT编程  | 我要评论

走错路,夏天有什么花,车辆交强险

ios uitableviewcell详解及按钮点击事件处理

今天突然做项目的时候,又遇到处理自定义的uitableviewcell上按钮的点击事件问题。我知道有两种方式,可是突然想不起来之前是怎么做的了,好记性不如烂笔头,还是记录一下吧。

1、第一种方式给button加上tag值

这里分为两种:一种是直接在原生的uitableviewcell上添加uibutton按钮,然后给uibutton设置tag值,然后在控制器里的方法里通过取数据,做界面跳转等。还是举个例子吧,省的回忆半天。

- (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; 
} 

然后在点击事件中取数据,加信息

- (void)photographbuttonclicked:(uibutton *)sender{ 
   user *user = _users[sender.tag]; 
  photopickercontroller *photopicker = [[photopickercontroller alloc] init]; 
  photopicker.user = user; 
  [self.navigationcontroller pushviewcontroller:photopicker animated:yes]; 
   
} 

以上两个方法都是在同一个控制器中。

2、自定义了uitableviewcell,那么就在uitableviewcell里添加一个代理方法。

#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 

然后再控制器中实现cell的代理方法即可

#pragma mark - termcelldelegate 
- (void)choseterm:(uibutton *)button 
{ 
  _clickindex = button.tag; 
  uialertview *alertview = [[uialertview alloc] initwithtitle:@"确定修改学期吗?" message:nil delegate:self cancelbuttontitle:@"取消" otherbuttontitles:@"确定", nil nil]; 
  [alertview show]; 
} 

当然,这里也可以做界面跳转,取数据依然用button的tag值。

补充:这里还可以在代理方法中将cell本身传回去,这样不用从数组取数据,直接利用cell的数据对象,更简单吆。

3、是直接在自定义的cell里面跳转,这种耦合性比较强。思路先是找到button的父控制器,然后做界面跳转或者其他操作。有这样一个工具方法

#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; 
} 

头文件就不写了,很简单的扩展。

- (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,然后点击事件是用block实现的。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网