- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想使用开关过滤 TableView 中的数据。我正在使用解析。假设我有一个 TableViewController 和一个 FilterViewController(普通 ViewController 类)。我想通过打开一些开关来过滤数据。并在按下“完成”按钮后显示过滤后的 TableView。我已经有了一些想法,但我不知道如何在 TableViewController 中设置更改。
谢谢
Filter.h
@protocol ViewControllerDelegate;
@interface FiltrViewController : UIViewController
{
IBOutlet UISwitch *switch1;
IBOutlet UISwitch *switch2;
IBOutlet UISwitch *switch3;
IBOutlet UISwitch *switch4;
IBOutlet UISwitch *switch5;
IBOutlet UISwitch *switch6;
IBOutlet UIBarButtonItem *button1;
IBOutlet UILabel *label;
}
@property (nonatomic, weak) id<ViewControllerDelegate> delegate;
@property (nonatomic, strong) PFObject *obj;
@property(nonatomic,strong) NSArray *keys;
+ (void) filter:(id<ViewControllerDelegate>)delegate;
-(IBAction)buttontouched:(id)sender;
-(IBAction)switch1:(id)sender;
@end
@protocol ViewControllerDelegate < NSObject>
-(void)filter;
@end
过滤器.m
@interface FiltrViewController (){
NSMutableDictionary* configG;
}
@property (retain) NSMutableDictionary* configG;
@end
@implementation FiltrViewController
@synthesize delegate;
@synthesize configG;
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
configG = [[NSMutableDictionary alloc] init];
}
return self;
}
-(void)filter
{
PFQuery *query = [PFQuery queryWithClassName:@"Countries"];
NSArray *keys = @[ @"Africa", @"Europe", @"South America", @"North America", @"Asia", @"Australia" ];
NSArray *defaultValues = @[ @YES, @YES, @YES, @YES, @YES, @YES ];
NSMutableDictionary *config = [NSMutableDictionary dictionaryWithObjects:defaultValues forKeys:keys];
NSSet *filter = [config keysOfEntriesPassingTest:
^BOOL (id key, NSNumber *value, BOOL *stop) {
return [value boolValue];
}];
[query whereKey:@"DescriptTitle" containedIn:[filter allObjects]];
self.keys = keys;
self.configG = config;
}
- (void)viewDidLoad
{
[super viewDidLoad];
}
-(IBAction)buttontouched:(id)sender;
{
[self dismissViewControllerAnimated:YES completion:nil];
[delegate filter];
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (IBAction)switch1:(UISwitch *)sender
{
[self.configG setObject:@([sender isOn]) forKey:[self.keys objectAtIndex:sender.tag]];
}
@end
TableView.m
- (void)FilterTable:(FiltrViewController *)viewController didChooseValue:(CGFloat)value {
[FiltrViewController filter:self];
}
过滤方法
- (void)filterController:(FilterViewController *)controller didEditConfig:(NSMutableDictionary *)config
{
NSSet *filter = [config keysOfEntriesPassingTest:
^BOOL (id key, NSNumber *value, BOOL *stop) {
return [value boolValue];
}];
PFQuery *query = [PFQuery queryWithClassName:@"Countries"];
[query whereKey:@"DescriptTitle" containedIn:[filter allObjects]];
[query findObjectsInBackgroundWithBlock:^(NSArray *objects, NSError *error) {
if (!error) {
//How can I pass filtered objects from Filter.m back into my TableView?
[self.MainTable reloadData];
NSLog(@"%u", objects.count);
}else{
}
}
];
最佳答案
通常,您不希望每次更改任何开关时都在后台运行多个查询。相反,您应该保留开关状态的配置(我想您已经在某处拥有它,因此您可以设置开关的初始状态)。
现在,当每个开关发生变化时,更新配置。按下完成按钮时,将配置发送回另一个 View Controller (或保存到共享存储/位置)。
在另一个 View Controller 中,检查是否有变化。如果有,请重新查询。但是……
仅进行 1 次查询。按原样设置查询类,但添加国家名称作为该查询的一部分:
// create array of the country names to include
NSArray *countries = ...;
[query whereKey:@"DescriptTitle" containedIn:countries];
现在事情变得更加高效且易于处理(一个请求和一个响应)。
配置:
您有一组国家,您希望能够启用/禁用它们。一个简单的配置是有一个字典,其中键是国家名称,值是包含相关联的 BOOL
状态值的 NSNumber
实例。
当您设置开关时,您可以使用这些值来设置状态。然后您可以在切换开关时更改状态。
完成后,我将使用委托(delegate)关系将修改后的配置传递回源 View Controller (您的 TableView Controller )。 (注意:通常代理也会关闭过滤器 View Controller ...)。
要获取查询的国家/地区列表,请查看使用 keysOfEntriesPassingTest:
。
设置:
NSArray *keys = @[ @"Africa", @"Europe", @"South America", @"North America", @"Asia", @"Australia" ];
NSArray *defaultValues = @[ @YES, @YES, @YES, @YES, @YES, @YES ];
NSMutableDictionary *config = [NSMutableDictionary dictionaryWithObjects:defaultValues forKeys:keys];
self.keys = keys;
self.config = config;
搜索(filter
方法):
NSSet *filter = [Dictionary keysOfEntriesPassingTest:
^BOOL (id key, NSNumber *value, BOOL *stop) {
return [value boolValue];
}];
PFQuery *query = [PFQuery queryWithClassName:@"Countries"];
[query whereKey:@"DescriptTitle" containedIn:[filter allObjects]];
// execute the query...
开关变化:
-- 假设开关有一个标签,它是 keys
数组的索引
- (IBAction)switchChanged:(UISwitch *)sender
{
[self.config setObject:@([sender isOn]) forKey:[self.keys objectAtIndex:sender.tag]];
}
按下完成按钮:
[self filter];
关于ios - 使用来自其他 View 的查询过滤 TableView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22286694/
我有三张 table 。表 A 有选项名称(即颜色、尺寸)。表 B 有选项值名称(即蓝色、红色、黑色等)。表C通过将选项名称id和选项名称值id放在一起来建立关系。 我的查询需要显示值和选项的名称,而
在mysql中,如何计算一行中的非空单元格?我只想计算某些列之间的单元格,比如第 3-10 列之间的单元格。不是所有的列...同样,仅在该行中。 最佳答案 如果你想这样做,只能在 sql 中使用名称而
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 7 年前。 Improve this ques
我正在为版本7.6进行Elasticsearch查询 我的查询是这样的: { "query": { "bool": { "should": [ {
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 7 年前。 Improve this ques
是否可以编写一个查询来检查任一子查询(而不是一个子查询)是否正确? SELECT * FROM employees e WHERE NOT EXISTS (
我找到了很多关于我的问题的答案,但问题没有解决 我有表格,有数据,例如: Data 1 Data 2 Data 3
以下查询返回错误: 查询: SELECT Id, FirstName, LastName, OwnerId, PersonEmail FROM Account WHERE lower(PersonEm
以下查询返回错误: 查询: SELECT Id, FirstName, LastName, OwnerId, PersonEmail FROM Account WHERE lower(PersonEm
我从 EditText 中获取了 String 值。以及提交查询的按钮。 String sql=editQuery.getText().toString();// SELECT * FROM empl
我有一个或多或少有效的查询(关于结果),但处理大约需要 45 秒。这对于在 GUI 中呈现数据来说肯定太长了。 所以我的需求是找到一个更快/更高效的查询(几毫秒左右会很好)我的数据表大约有 3000
这是我第一次使用 Stack Overflow,所以我希望我以正确的方式提出这个问题。 我有 2 个 SQL 查询,我正在尝试比较和识别缺失值,尽管我无法将 NULL 字段添加到第二个查询中以识别缺失
什么是动态 SQL 查询?何时需要使用动态 SQL 查询?我使用的是 SQL Server 2005。 最佳答案 这里有几篇文章: Introduction to Dynamic SQL Dynami
include "mysql.php"; $query= "SELECT ID,name,displayname,established,summary,searchlink,im
我有一个查询要“转换”为 mysql。这是查询: select top 5 * from (select id, firstName, lastName, sum(fileSize) as To
通过我的研究,我发现至少从 EF 4.1 开始,EF 查询上的 .ToString() 方法将返回要运行的 SQL。事实上,这对我来说非常有用,使用 Entity Framework 5 和 6。 但
我在构造查询来执行以下操作时遇到问题: 按activity_type_id过滤联系人,仅显示最近事件具有所需activity_type_id或为NULL(无事件)的联系人 表格结构如下: 一个联系人可
如何让我输入数据库的信息在输入数据 5 分钟后自行更新? 假设我有一张 table : +--+--+-----+ |id|ip|count| +--+--+-----+ |
我正在尝试搜索正好是 4 位数字的 ID,我知道我需要使用 LENGTH() 字符串函数,但找不到如何使用它的示例。我正在尝试以下(和其他变体)但它们不起作用。 SELECT max(car_id)
我有一个在 mysql 上运行良好的 sql 查询(查询 + 连接): select sum(pa.price) from user u , purchase pu , pack pa where (
我是一名优秀的程序员,十分优秀!