可能大家对- (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"]);

直接得到字典中namekey对应的值组成的数组,显然比循环取值再加入到新数组中方便快捷:

(

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;要方便很多

05-11 08:21