标签:
可能大家对- (id)valueForKeyPath:(NSString *)keyPath
方法不是很了解。 其实这个方法非常的强大,举个例子:
NSArray *array = @[@"name", @"w", @"aa", @"jimsa"]; NSLog(@"%@", [array valueForKeyPath:@"uppercaseString"]);
输出:
(
NAME,
W,
AA,
JIMSA
)
相当于数组中的每个成员执行了uppercaseString
方法,然后把返回的对象组成一个新数组返回。既然可以用uppercaseString
方法,那么NSString的其他方法也可以,比如:
[array valueForKeyPath:@"length"]
返回每个字符串长度的组成的数组。只要你能想到的成员实例方法都可以这么用。
如果你觉得这个方法就这么点功能,那就错了。还是举具体的例子
NSArray *array = @[@1, @2, @3, @4, @10]; 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", @"123", @"jimsa", @"123"]; NSLog(@"%@", [array valueForKeyPath:@"@distinctUnionOfObjects.self"]);
打印出的结果:
(jjim,w,123,jimsa);
NSArray *array = @[@{@"name": @"Lily",@"code": @1}, @{@"name": @"tom",@"code": @2}, @{@"name": @"jerry",@"code": @1}, @{@"name": @"Bob",@"code": @1}]; NSLog(@"%@", [array valueForKeyPath:@"name"]);
直接得到字典中name
key对应的值组成的数组,显然比循环取值再加入到新数组中方便快捷:
(
Lily,
tom,
jerry,
Bob
)
同样可以嵌套使用,先剔除name
对应值的重复数据再取值:
NSArray *array = @[@{@"name": @"Lily",@"code": @1}, @{@"name": @"tom",@"code": @2}, @{@"name": @"tom",@"code": @1}, @{@"name": @"jerry",@"code": @1}]; NSLog(@"%@", [array valueForKeyPath:@"@distinctUnionOfObjects.name"]);
打印 ( Lily, tom, jerry )
[searchField setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];
比起重写- (void)drawPlaceholderInRect:(CGRect)rect;
要方便很多
标签:
原文地址:http://www.cnblogs.com/pengpengzhang/p/4557712.html