cellForRowAtIndexPath崩溃问题

static NSString *CellIdentifier = @"SampleCell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

    if (cell == nil) {

        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];

    }


用xcode 自动生成的TableViewController有时候会是这样子的

static NSString *CellIdentifier = @"SampleCell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];


这句话好像有问题,我在使用的过程种都会崩溃。改成开头那样子就没问题了。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
源码D3HttpClient,# D3HttpClient D3HttpClient, try to make a simple way to network request and init tableview ##简介 配置好,一句代码可以集成UITableView的上下拉刷新处理好数据。 解决两个问题: 1.简化UITableView的上下拉刷新。(IOS开发中最常用到的控件不过与UITableView了。这个项目目的就是用最简单的方法初始化UITableView的上下拉刷新,不用管理网络访问,只需要处理cellForRowAtIndexPath这些方法即可) 2.简化网络访问。(使用配置的方法设置好要访问的url和参数,简化网络访问) ##使用 ###1.配置好URL及参数 let URL_LIST_CITY = "http://route.showapi.com/170-48"//列出城市 let URL_LIST_CITY_NEWS = "http://route.showapi.com/170-47"//列出城市新闻 let URL_LIST_HAHA = "http://route.showapi.com/341-1"//列出笑话 let APIS = [ URL_LIST_CITY:["showapi_timestamp"], URL_LIST_CITY_NEWS:["showapi_timestamp","page"], URL_LIST_HAHA:["showapi_timestamp","time","page"] ] ###2.初始化D3Dao D3Dao.getInstance().initApis(APIS) //初始化URL D3Dao.getInstance().initNomalParms(["showapi_appid":"4191","showapi_sign":"e4c39181ddd84915b23a886e35e04451"]) //初始化常用参数,无则不用 ###3.初始化tableView(记得继承D3TableView,对应方法介绍看代码) d3TableView.initRefresh(City.self, keys: ["showapi_res_body","pagebean","contentlist"], url: URL_LIST_CITY_NEWS, datas: [timestamp]) 到此,tableView已经集成上下拉刷新,cellForRowAtIndexPath这些方法自己实现。tableView.arr即是需要的数据 ###4.简化的网络请求 D3Dao.getInstance().post(URL_LIST_CITY, datas: [timestamp], suc: {(statusCode,data) in println(data) }) ##补充 1.需要查看配置才知道需要传什么参数。(平时好像也需要一边查api文档吧) 2.希望集成自己的上下拉方式,json转换,网络请求的.修改处已用//FIXME:标记,我就不封装了。 3.如以上做法有问题,希望有大牛指正我的做法,这是个人的想法而已
您可以使用以下代码将YYLabel添加到UITableViewCell中,并在YYLabel中插入NSMutableAttributedString中的attachment,attachment中嵌入UITextView: ``` - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell" forIndexPath:indexPath]; if (!cell) { cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"]; } YYLabel *label = [[YYLabel alloc] initWithFrame:CGRectMake(10, 10, cell.contentView.bounds.size.width - 20, )]; label.numberOfLines = ; [cell.contentView addSubview:label]; NSMutableAttributedString *attributedText = [[NSMutableAttributedString alloc] initWithString:@"这是一段文字"]; // 创建attachment UITextView *textView = [[UITextView alloc] initWithFrame:CGRectMake(, , cell.contentView.bounds.size.width - 20, 100)]; textView.text = @"这是一个UITextView"; textView.scrollEnabled = YES; textView.backgroundColor = [UIColor clearColor]; textView.userInteractionEnabled = NO; [textView sizeToFit]; NSAttributedString *attachment = [NSAttributedString attachmentStringWithContent:textView contentMode:UIViewContentModeScaleAspectFit attachmentSize:textView.bounds.size alignToFont:[UIFont systemFontOfSize:14] alignment:YYTextVerticalAlignmentCenter]; [attributedText appendAttributedString:attachment]; label.attributedText = attributedText; [label sizeToFit]; return cell; } ``` 要处理UITextView与TableView滚动冲突的问题,您可以在UITextView上添加一个手势识别器,并将其禁用掉,这样就可以避免冲突了: ``` UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:nil]; [textView addGestureRecognizer:tapGesture]; tapGesture.enabled = NO; ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值