1、
http://stackoverflow.com/questions/12714737/where-does-the-indexpath-of-dequeuereusablecellwithidentifierforindexpath-get
The most important difference between dequeueReusableCellWithIdentifier:
and dequeueReusableCellWithIdentifier:indexPath:
is that they are different methods! Thus they can behave differently, and they do. This has nothing to do with the indexPath, really; we just need a way to distinguish them.
The New Way
In particular, if you call dequeueReusableCellWithIdentifier:indexPath:
, this is a sign that you are using the new iOS 6 register-and-dequeue system. So, if you have failed to register this identifier, you'll get a nice crash and a log message explaining the problem. This method will never return nil; it always returns a cell, either by creating a new one or by reusing one.
The Old Way
On the other hand, plain and simple dequeueReusableCellWithIdentifier:
is old and has to be backward compatible. If you haven't registered this identifier, it won't complain: it will just return nil, leaving you high and dry. You'll have to create the cell yourself, as in the bad old days.
EDIT: But see also the answer by @svena! The new way (with indexPath:
) has a second advantage I didn't know about: the cell is correctly sized at the time it is returned to you.
http://bbs.csdn.net/topics/390330467
1 这个方法在SDK5.0是运行不起来的。
2 如果需要使用这个方法,你必须使用配套的方法来一起用,下面两个配套方法:
1
2
3
4
5
|
// Beginning in iOS 6, clients can register a nib or class for each cell.
// If all reuse identifiers are registered, use the newer -dequeueReusableCellWithIdentifier:forIndexPath: to guarantee that a cell instance is returned.
// Instances returned from the new dequeue method will also be properly sized when they are returned.
- (
void
)registerNib:(
UINib
*)nib forCellReuseIdentifier:(
NSString
*)identifier
NS_AVAILABLE_IOS
(5_0);
- (
void
)registerClass:(Class)cellClass forCellReuseIdentifier:(
NSString
*)identifier
NS_AVAILABLE_IOS
(6_0);
|
注意看上面的注释
3 比如你已经用NIB做了一个Cell,或者自定义了一个Cell。我们在你创建UITableView的时候,就可以顺带
1
2
|
self
.tableView.backgroundColor = xxxx;
[
self
.tableView registerClass:[CustomCell
class
] forCellReuseIdentifier:@
"CustomCell"
];
|
这样你在- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath这个方法里,你就可以省下这些代码:
1
2
3
4
5
|
static
NSString
*CellIdentifier = @
"Cell"
;
if
(cell ==
nil
) {
cell = [[
UITableViewCell
alloc] initWithStyle:
UITableViewCellStyleDefault
reuseIdentifier:CellIdentifier];
//设置你的cell
}
|
而只需要
1
|
UITableViewCell
*cell = [tableView dequeueReusableCellWithIdentifier:@
"Cell"
forIndexPath:indexPath];
|
这样就够了,这下你明白了吗?