023.Key 路径

来源:互联网 发布:sql存储过程输出参数 编辑:程序博客网 时间:2024/05/01 08:51
---------------  main.m  ---------------
#import <Foundation/Foundation.h>
#import "FKItem.h"

@interface FKOrder : NSObject
@property(nonatomic , strong) FKItem* item;
@property(nonatomic , assign) int amount;
-(
int) totalPrice;
@end

@implementation FKOrder
-(
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"]);
}

一、编写本节代码的具体步骤:
1.可仿照第二章001节的代码编写步骤,可以把类的接口文件,类的实现文件写在main.m文件中。
2.上一节代码有FKItem.h,FKItem.m与main.m三个源文件,本节代码要与上一节中的FKItem.m文件共同编译运行。

二、本节代码涉及到的知识点:
1.KVC操作Key路径的方法如下:
  setValue:forKeyPath: // 根据Key路径设置属性值
  valueForKeyPath:     // 根据Key路径获取属性值
2.本节代码中,FKOrder这个类的对象,有一个FKItem类型的item属性,
  而FKItem这个类的对象,有name属性,那么KVC可以通过item.name的方式来操作这些属性。
3.FKItem.h文件不必与本节代码共同编译,因为我们已经通过#import "FKItem.h将其导入进来了。
4.我们在新建一个类的时候,我们发现在右侧属性栏中,这个类的.h文件默认是不勾选Target Membership的。
  就是因为.h文件主要是用#import来导入的。

0 0
原创粉丝点击