---------------
main.m
---------------
#import
<Foundation/Foundation.h>
#import
"FKItem.h"
@interface
FKOrder : NSObject
@property ( nonatomic , strong ) FKItem* item;
@property ( nonatomic , assign ) int amount;
-( int ) totalPrice;
@property ( nonatomic , strong ) FKItem* item;
@property ( nonatomic , assign ) int amount;
-( int ) totalPrice;
@end
@implementation
FKOrder
-( int ) totalPrice
{
-( int ) totalPrice
{
return _item.price * _amount;
}
@end
int
main()
{
FKOrder* order = [[FKOrder alloc] init];
[order setValue:
@"12"
forKey:
@"amount"
];
[order setValue:[[FKItem alloc] init] forKey: @"item" ];
// 使用 setValue:forKeyPath 设置 item 属性的 name 属性
[order setValue: @" 鼠标 " forKeyPath: @"item.name" ];
// 使用 valueForKeyPath 来获取复合属性值
[order setValue:[NSNumber numberWithInt: 20 ] forKeyPath: @"item.price" ];
NSLog( @" 订单包含 %@ 个 %@ ,总价为: %@" , [order valueForKey: @"amount" ] ,
[order valueForKeyPath: @"item.name" ],
[order valueForKey: @"totalPrice" ]);
[order setValue:[[FKItem alloc] init] forKey: @"item" ];
// 使用 setValue:forKeyPath 设置 item 属性的 name 属性
[order setValue: @" 鼠标 " forKeyPath: @"item.name" ];
// 使用 valueForKeyPath 来获取复合属性值
[order setValue:[NSNumber numberWithInt: 20 ] forKeyPath: @"item.price" ];
NSLog( @" 订单包含 %@ 个 %@ ,总价为: %@" , [order valueForKey: @"amount" ] ,
[order valueForKeyPath: @"item.name" ],
[order valueForKey: @"totalPrice" ]);
}
一、编写本节代码的具体步骤:
1.可仿照
第二章
001节的代码编写步骤,可以把类的接口文件,类的实现文件写在main.m文件中。
2.上一节代码有FKItem.h,FKItem.m与main.m三个源文件,本节代码要与上一节中的FKItem.m文件共同编译运行。
二、本节代码涉及到的知识点:
1.KVC操作Key路径的方法如下:
setValue:forKeyPath:
// 根据Key路径设置属性值
v
alueForKeyPath:
// 根据Key路径获取属性值
2.本节代码中,FKOrder这个类的对象,有一个FKItem类型的item属性,
而FKItem这个类的对象,有name属性,那么KVC可以通过item.name的方式来操作这些属性。
3.
FKItem.h文件不必与本节代码共同编译,因为我们已经通过#import "FKItem.h”将其导入进来了。
4.我们在新建一个类的时候,我们发现在右侧属性栏中,这个类的.h文件默认是不勾选Target Membership的。
就是因为.h文件主要是用#import来导入的。