可能大家对- (id)valueForKeyPath:(NSString *)keyPath
方法不是很了解。 其实这个方法非常的强大,举个例子:
NSArray *array = @[@"name", @"w", @"aa", @"jimsa"];
NSLog(@"%@", [array valueForKeyPath:@"uppercaseString"]);
输出:
(
NAME,
W,
AA,
JIMSA
)
相当于数组中的每个成员执行了uppercaseString
方法,然后把返回的对象组成一个新数组返回。既然可以用uppercaseString
方法,那么NSString的其他方法也可以,比如:
[array valueForKeyPath:@"length"]
返回每个字符串长度的组成的数组。只要你能想到的成员实例方法都可以这么用。
如果你觉得这个方法就这么点功能,那就错了。还是举具体的例子
对NSNumber数组快速计算数组求和、平均数、最大值、最小值:
NSArray *array = @[@, @, @, @, @]; NSNumber *sum = [array valueForKeyPath:@"@sum.self"];
NSNumber *avg = [array valueForKeyPath:@"@avg.self"];
NSNumber *max = [array valueForKeyPath:@"@max.self"];
NSNumber *min = [array valueForKeyPath:@"@min.self"];
或者指定输出类型:
NSNumber *sum = [array valueForKeyPath:@"@sum.floatValue"];
NSNumber *avg = [array valueForKeyPath:@"@avg.floatValue"];
NSNumber *max = [array valueForKeyPath:@"@max.floatValue"];
NSNumber *min = [array valueForKeyPath:@"@min.floatValue"];
剔除重复数据:
NSArray *array = @[@"jjim", @"w", @"", @"jimsa", @""];
NSLog(@"%@", [array valueForKeyPath:@"@distinctUnionOfObjects.self"]);
打印出的结果:
(jjim,w,123,jimsa);
对NSDictionary数组快速找出相应key对的值:
NSArray *array = @[@{@"name": @"Lily",@"code": @},
@{@"name": @"tom",@"code": @},
@{@"name": @"jerry",@"code": @},
@{@"name": @"Bob",@"code": @}];
NSLog(@"%@", [array valueForKeyPath:@"name"]);
直接得到字典中name
key对应的值组成的数组,显然比循环取值再加入到新数组中方便快捷:
(
Lily,
tom,
jerry,
Bob
)
同样可以嵌套使用,先剔除name
对应值的重复数据再取值:
NSArray *array = @[@{@"name": @"Lily",@"code": @},
@{@"name": @"tom",@"code": @},
@{@"name": @"tom",@"code": @},
@{@"name": @"jerry",@"code": @}]; NSLog(@"%@", [array valueForKeyPath:@"@distinctUnionOfObjects.name"]);
打印 ( Lily, tom, jerry )
改变UITextfiedl的placeholder的颜色:
[searchField setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];
比起重写- (void)drawPlaceholderInRect:(CGRect)rect;
要方便很多