Fork me on GitHub

让数据随分批显示的方法

iPhone屏幕尺寸是有限的,如果需要显示的数据很多,可以先数据放到一个table中,先显示10条,table底部有一察看更多选项,点击察 看更多查看解析的剩余数据。基本上就是数据源里先只放10条, 点击最后一个cell时, 添加更多的数据到数据源中. 比如:

数据源是个array:

NSMutableArray *items;
ViewController的这个方法返回数据条数: +1是为了显示"加载更多"的那个cell
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
         int count = [items count];
     return   count + 1;
}

这个方法定制cell的显示, 尤其是"加载更多"的那个cell:

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
     if([indexPath row] == ([items count])) {
         //创建loadMoreCell
         return loadMoreCell;
     }
    
     //create your data cell

     return cell;
}

还要处理"加载更多"的那个cell的选择事件,触发一个方法来加载更多数据到列表

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
    
     if (indexPath.row == [items count]) {
         [loadMoreCell setDisplayText:@"loading more ..."];
         [loadMoreCell setAnimating:YES];
         [self performSelectorInBackground:@selector(loadMore) withObject:nil];
         //[loadMoreCell setHighlighted:NO];
         [tableView deselectRowAtIndexPath:indexPath animated:YES];
         return;
     }

     //其他cell的事件
     
}

加载数据的方法:

-(void)loadMore
{
     NSMutableArray *more; 
         //加载你的数据
     [self performSelectorOnMainThread:@selector(appendTableWith:) withObject:more waitUntilDone:NO];
}

添加数据到列表:

-(void) appendTableWith:(NSMutableArray *)data
{

     for (int i=0;i<[data count];i++) {
         [items addObject:[data objectAtIndex:i]];
     }
     NSMutableArray *insertIndexPaths = [NSMutableArray arrayWithCapacity:10];
     for (int ind = 0; ind < [data count]; ind++) {
         NSIndexPath     *newPath =   [NSIndexPath indexPathForRow:[items indexOfObject:[data objectAtIndex:ind]] inSection:0];

//因items原已有数据,后添加的数据的row要在原数据基础上增加,最简单的方法就是   indexOfObject:得到当前row。


         [insertIndexPaths addObject:newPath];
     }
     [self.tableView insertRowsAtIndexPaths:insertIndexPaths withRowAnimation:UITableViewRowAnimationFade];

}

posted on 2012-03-26 17:30  pengyingh  阅读(297)  评论(0编辑  收藏  举报

导航