023.Key 路径

---------------  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路径设置属性值
  v alueForKeyPath:      // 根据Key路径获取属性值
2.本节代码中,FKOrder这个类的对象,有一个FKItem类型的item属性,
  而FKItem这个类的对象,有name属性,那么KVC可以通过item.name的方式来操作这些属性。
3. FKItem.h文件不必与本节代码共同编译,因为我们已经通过#import "FKItem.h将其导入进来了。
4.我们在新建一个类的时候,我们发现在右侧属性栏中,这个类的.h文件默认是不勾选Target Membership的。
  就是因为.h文件主要是用#import来导入的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值