2012-07-05 2 views
1

У меня есть модель, которую я хочу проверить больше плагинов, если плагины загружаются, а затем присоединяют модели в плагине к модели человека. Я использую этот метод? Но разные результаты в модели и действии. Является ли другой метод лучше, чем конструкция для привязки больше для проверки плагина.cakephp attach more ownedsto

class Comment extends AppModel { 

/** 
* @see Model::$belongsTo 
*/ 
    public $belongsTo = array(
     'Content' => array(
      'className' => 'Content', 
      'foreignKey' => 'object_id', 
      'conditions' => array(
       'Comment.object_id = Content.id', 
      ) 
     ), 
    ); 

/** 
* @see Model::__construct 
*/ 
    public function __construct($id = false, $table = null, $ds = null) { 
     // parent 
     parent::__construct($id, $table, $ds); 

     // check for newsstudio 
     if (CakePlugin::loaded('NewModel')) { 
      $this->bindModel(
       array('belongsTo' => array(
        'NewModel' => array(
         'className' => 'NewModel.NewModel', 
         'foreignKey' => 'object_id', 
         'conditions' => array(
          'Comment.object_id = NewModel.id', 
         ) 
        ) 
       ) 
      )); 
     } 

     var_dump($this->belongsTo); // correct! NewModel added to blongsto 
    } 
} 

// but in action during use. Plugin loaded but 
var_dump($this->Comment->belongsTo); // incorrect! just `Content` added 

ответ

0

Учитывая вы делаете это в __construct, вы можете также просто добавить его в $belongsTo собственности перед вызовом родителей, который позволит сэкономить несколько циклов процессора, как вы не делаете дополнительный вызов метода.

class Comment extends AppModel { 

/** 
* @see Model::$belongsTo 
*/ 
    public $belongsTo = array(
     'Content' => array(
      'className' => 'Content', 
      'foreignKey' => 'object_id', 
      'conditions' => array(
       'Comment.object_id = Content.id', 
      ) 
     ), 
    ); 

/** 
* @see Model::__construct 
*/ 
    public function __construct($id = false, $table = null, $ds = null) { 
     // check for newsstudio 
     if (CakePlugin::loaded('NewModel')) { 
      $this->belongsTo['NewModel'] = array(
         'className' => 'NewModel.NewModel', 
         'foreignKey' => 'object_id', 
         'conditions' => array(
          'Comment.object_id = NewModel.id', 
         ) 
        ); 
     } 
     parent::__construct($id, $table, $ds); 
    } 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^