有关tabble的局部刷新,左滑删除cell或者section

2017-08-25  本文已影响0人  一只不会飞的小艳子

UITableView对于iOS开发者来说一定不会陌生,很有可能你的APP很多界面都用到它。关于UITableView的文章,想必已经不计其数,没事可以多看看。特别是UITableView优化的文章,非常值得仔细琢磨一番。

今天我们来看看如何刷新UITableView的,一般情况下,刷新UITableView,我们会直接调用reloadData方法。

1.刷新UITableView

[self.tableView reloadData];

reloadData是刷新整个UITableView,有时候,我们可能需要局部刷新。比如:只刷新一个cell、只刷新一个section等等。这个时候在调用reloadData方法,虽然用户看不出来,但是有些浪费资源。

2.刷新局部cell

NSIndexPath *indexPath = [NSIndexPath indexPathForRow:0 inSection:0];

[self.tableView reloadRowsAtIndexPaths:[NSArray arrayWithObjects:indexPath,nil] withRowAnimation:UITableViewRowAnimationFade];

这样就可以很方便的刷新第一个section的第一个cell。虽然看起来代码多了,但是确实比较节省资源。尽量少的刷新,也是UITableView的一种优化。

3.局部刷新section

NSIndexSet *indexSet = [[NSIndexSet alloc] initWithIndex:0];

[self.tableView reloadSections:indexSet withRowAnimation:UITableViewRowAnimationFade];

上面这段代码是刷新第0个section。

4.左滑动删除cell或者section(以model为例)

HistoryModel*m =_dataArray[indexPath.section];

HistoryInfoModel*tempModel = m.data[indexPath.row];

//删除某一行

//1.更新数据

[m.dataremoveObjectAtIndex:indexPath.row];

//[myTableView reloadData];//浪费资源

//2.局部更新UI

if(m.data.count>0) {

[myTableViewdeleteRowsAtIndexPaths:[NSArrayarrayWithObjects:indexPath,nil]withRowAnimation:UITableViewRowAnimationFade];

}else{

//这里是删除整个section

[_dataArrayremoveObject:m];

[myTableViewdeleteSections:[NSIndexSetindexSetWithIndex:indexPath.section]withRowAnimation:UITableViewRowAnimationFade];

}

刷新动画

刷新UITableView还有几个动画:

typedef NS_ENUM(NSInteger, UITableViewRowAnimation) {

UITableViewRowAnimationFade,   //淡入淡出

UITableViewRowAnimationRight,  //从右滑入         // slide in from right (or out to right)

UITableViewRowAnimationLeft,   //从左滑入

UITableViewRowAnimationTop,     //从上滑入

UITableViewRowAnimationBottom,  //从下滑入

UITableViewRowAnimationNone,            // available in iOS 3.0

UITableViewRowAnimationMiddle,          // available in iOS 3.2.  attempts to keep cell centered in the space it will/did occupy

UITableViewRowAnimationAutomatic = 100  // available in iOS 5.0.  chooses an appropriate animation style for you

};

上一篇下一篇

猜你喜欢

热点阅读