先来点伪代码:
#import <MJExtension.h>
//用来接收AFNetWorking请求的数据
@property (nonatomic, strong)NSArray *jsonData;
@implementation xxxxViewController
- (void)viewDidLoad {
[super viewDidLoad];
[self getNetWorking];
}
-(void)getNetWorking{
AFHTTPSessionManager *manager =[AFHTTPSessionManager manager];
[manager GET:@"http://127.0.0.1:8000/api/info/" parameters:nil progress:^(NSProgress * _Nonnull downloadProgress) {
//进度
//进度
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
self.jsonData=[xxxModel mj_ObjectArrayWithKeyValuesArray:responseObject[@"news"]];
[self.xxxx reloadData];
//此处能打印出获取到的数据信息
NSLog(@"%@",self.jsonData);
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
// error 错误信息
}];
}
@end
上面代码中请求后将responseObject
返回的数据传给了self.jsonData
,用NSLog打印后有值,但是为什么在UITableView
的下面方法中获取到的数据个数为0,请问是什么原因,谢谢~!
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
//打印数据个数
SSTLog(@"jsonData个数===%ld",self.jsonData.count);
//这里为0
return self.jsonData.count;
}
打印后的信息如下:
**折腾了一天终于搞定了原来是一个默认选中UITableView第一行的一个方法捣的鬼。重复测试了好几遍,再次感谢回复我的各位兄台,非常的感激~跪拜!
去掉下面的代码就好了。。。(不知道有没有替换这个的方法,有的话望能告知,非常感谢~!)**
//默认选中第一行
[self.leftTableView selectRowAtIndexPath:[NSIndexPath indexPathForRow:0 inSection:0] animated:NO scrollPosition:UITableViewScrollPositionTop];
目前来看,代码没有问题。
出现这种现象的可能原因是,tableView 被添加到视图层级后,会调用多次
numberOfRowsInSection
,此时本地并没有数据,所以返回0。当获取到数据后,才能显示正确的数量。
获取到数据后,tableView reload一下
因为打印0的时候,那会网络数据还没有获取到..?