Я знаю, что это проблема с запятой, но cellForRowAtIndexPath: не вызывается, когда я использую [actionTableView reloadData];
. Я уже связал dataSource и delegate благодаря раскадровке, но это не решает проблему.
Вот часть моего кода:
SearchViewController.h
#import <UIKit/UIKit.h>
@interface SearchViewController : UIViewController <UITableViewDelegate, UITableViewDataSource, UISearchBarDelegate, UISearchDisplayDelegate>
@property (strong, nonatomic) IBOutlet UITableView *actionTableView;
@property (strong, nonatomic) IBOutlet UISearchBar *actionSearchBar;
@property (strong, nonatomic) NSMutableArray *actionsArray;
@property (strong, nonatomic) NSMutableArray *filteredActionArray;
@end
SearchViewController.m
#import "SearchViewController.h"
#import "Action.h"
@interface SearchViewController ()
@end
@implementation SearchViewController
@synthesize actionsArray, actionTableView, filteredActionArray, actionSearchBar;
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return 1;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
if (tableView == self.searchDisplayController.searchResultsTableView) {
return [filteredActionArray count];
} else {
return [actionsArray count];
}
}
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if ( cell == nil ) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];
}
NSLog(@"Aloha");
// Create a new Action object
Action *a = nil;
if (tableView == self.searchDisplayController.searchResultsTableView) {
a = [filteredActionArray objectAtIndex:indexPath.row];
} else {
a = [actionsArray objectAtIndex:indexPath.row];
}
// Configure the cell
cell.textLabel.text = a.nomAction;
[cell setAccessoryType:UITableViewCellAccessoryDisclosureIndicator];
return cell;
}
-(void)filterContentForSearchText:(NSString*)searchText scope:(NSString*)scope {
// Update the filtered array based on the search text and scope.
// Remove all objects from the filtered search array
[self.filteredActionArray removeAllObjects];
// Filter the array using NSPredicate
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF.nomAction contains[c] %@",searchText];
filteredActionArray = [NSMutableArray arrayWithArray:[actionsArray filteredArrayUsingPredicate:predicate]];
}
-(BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString {
// Tells the table data source to reload when text changes
[self filterContentForSearchText:searchString scope:
[[self.searchDisplayController.searchBar scopeButtonTitles]objectAtIndex:[self.searchDisplayController.searchBar selectedScopeButtonIndex]]];
// Return YES to cause the search result table view to be reloaded.
return YES;
}
-(BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchScope:(NSInteger)searchOption {
// Tells the table data source to reload when scope bar selection changes
[self filterContentForSearchText:self.searchDisplayController.searchBar.text scope:
[[self.searchDisplayController.searchBar scopeButtonTitles] objectAtIndex:searchOption]];
// Return YES to cause the search result table view to be reloaded.
return YES;
}
Как видите, я также использую searchBar для фильтрации массива, но без этого он тоже не работает.
EDIT: СПЕЦИФИКАЦИЯ ПРОБЛЕМЫ: reloadData
работает только в том случае, если я вызываю его в viewController. Нет, если я вызову его из другого viewController. Очевидно, что в обоих случаях я вызываю одну и ту же функцию updatingTableView
, расположенную в контроллере представления, где находится tableView. Есть идеи перезагрузить tableView из другого ViewController?
SearchViewController.m (работает)
-(IBAction)update{
[self updatingTableView:nil];
}
-(void)updatingTableView:(NSData*)someData {
actionsArray = [NSArray arrayWithObjects:@"item1", @"item2", @"item3", nil];
[actionTableView reloadData];
}
AnotherViewController.m (не работает)
-(IBAction)updateFromElsewhere{
UIStoryboard *mainStoryboard = [UIStoryboard storyboardWithName:@"Main"
bundle: nil];
SearchViewController *searchViewController = (SearchViewController*) [mainStoryboard
instantiateViewControllerWithIdentifier: @"searchcontroller_id"];
[searchViewController updatingTableView:nil];
}
NB: я могу без проблем передать некоторые данные из контроллера представления в другой.
tableView: numberOfRowsInSection
не возвращают 0 - person teamnorge   schedule 19.07.2015numberOfSectionsInTableView
иnumberOfRowsInSection
даже не называются - person romain64   schedule 19.07.2015awakeFromNib
, где вы поместитеactionTableView.delegate = self
- person teamnorge   schedule 19.07.2015awakeFromNib
тоже не работает.numberOfSectionsInTableView
иnumberOfRowsInSection
вызываются только один раз при открытии приложения, но в этот момент массив пуст. Затем, когда я использую IBAction для загрузки данных в NSArray, а затем обрабатываюreloadData
, они больше не вызываются. - person romain64   schedule 19.07.2015numberOfRowsInSectionare
иnumberOfSectionsInTableView
можно положить свои reload data внутрь[tableView beginUpdates]; [tableView reloadData]; [tableView endUpdates];
в общем не обязательно если не удалять/вставлять ячейки, а просто как обходной путь чтобы понять что не так. - person teamnorge   schedule 19.07.2015beginUpdates
иendUpdates
. Да, я начну все с нуля. У меня есть другой проект с точно таким же кодом и где он работает, это странно. - person romain64   schedule 19.07.2015