zoukankan      html  css  js  c++  java
  • 代理、通知、KVO

    • 代理设计模式的作用:

      • 1.A对象监听B对象的一些行为,A成为B的代理
      • 2.B对象想告诉A对象一些事情,A成为B的代理
    • 代理设计模式的总结:

      • 如果你想监听别人的一些行为,那么你就要成为别人的代理
      • 如果你想告诉别人一些事情,那么就让别人成为你的代理
    • 代理设计模式的开发步骤

      • 1.拟一份协议(协议名字的格式:控件名 + Delegate),在协议里面声明一些代理方法(一般代理方法都是@optional)
      • 2.声明一个代理属性:@property (nonatomic, weak) id<代理协议> delegate;
      • 3.在内部发生某些行为时,调用代理对应的代理方法,通知代理内部发生什么事
      • 4.设置代理:xxx.delegate = yyy;
      • 5.yyy对象遵守协议,实现代理方法

    通知

    • 通知中心发出通知
      // aa对象在通知中心发出了cc通知
      [[NSNotificationCenter defaultCenter] postNotificationName:@"cc" object:@"aa"];
      //bb对象监听了任何对象发出的cc通知,一旦有对象发出了cc通知,bb对象就会调用它的test方法
      [[NSNotificationCenter defaultCenter] addObserver:bb selector:@selector(test) name:@"cc" object:nil];

    代理和通知的区别

    • 代理:1个对象只能告诉另1个对象发生了什么事
    • 通知:1个对象可以告诉N个对象发生了什么事

    KVO

    • KVO(Key Value Observing)常用作用:监听模型属性值的改变
    • KVO的使用步骤
    // cc监听了aa的name属性的改变
    [aa addObserver:cc forKeyPath:@"name" options: NSKeyValueObservingOptionOld context:nil];
    
    // cc得实现监听方法
    /**
     * 当监听到object的keyPath属性发生了改变
     */
    - (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
    {
        NSLog(@"监听到%@对象的%@属性发生了改变, %@", object, keyPath, change);
    }
    注意:在对象销毁的时候要移除观察者
  • 相关阅读:
    实验四
    实验一、二
    实验
    网上摘录
    网上摘录(琐碎信息)
    angularJsUIbootstrap系列教程1(使用前的准备)
    angularJS在本机运行时的注意事项
    angularJS在创建指令需要注意的问题(指令中使用ngRepeat)
    angularJsUIbootstrap系列教程2(According)
    ASP.NET Web Forms 4.5的新特性
  • 原文地址:https://www.cnblogs.com/luoze/p/5467948.html
Copyright © 2011-2022 走看看