CakePHP - 正确的做法有很多通过

时间:2013-08-05 23:54:41

标签: php cakephp model

我有3个模特

分类

 class Category extends AppModel {
     public $belongsTo = array(
        'Parent' => array(
            'className' => 'Category',
            'foreignKey' => 'parent_id'
        ),
     );
     public $hasMany = array(
         'Children' => array(
            'className' => 'Category',
            'foreignKey' => 'parent_id'
         ), 
        'UserCategoryMeta'
     );
}

用户:

class User extends AppModel {
    public $hasMany = array(
        'UserCategoryMeta' => array(
            'className' => 'UserCategoryMeta',
            'foreignKey' => 'user_id',
        ),
    );
}

UserCategoryMeta:

class UserCategoryMeta extends AppModel
{
    public $belongsTo = array(
        'User', 'Category'
    );
}

我需要做的是让每个用户都能够选择多个类别,并且对于每个关联,我需要用户设置搜索条件,这只是数据库中的1个字段。

所以UserCategoryMeta表看起来像这样:

id  |  user_id  | category_id  |  search_terms

我找到了一种方法可行,但看起来非常黑客。

在用户控制器中我有:

$Categories = $this->User->Category->find('list');

然后在添加视图中,我有复选框:

echo $this->Form->input('Category.Category',array(
    'type' => 'select', 
    'multiple' =>'checkbox',
    'options' => $Categories,
));

然后,我可以获得每个复选框以在其旁边输入搜索字词的唯一方法是在添加视图中执行此操作:

foreach ($Categories as $key => $category){
    echo '<input type="text" id="Category'.$key.'SearchTerms" name="data[Category][search_terms]['.$key.']"><br/>';
}

这产生了我想要的东西,但很明显,因为我只是在表单获得提交时创建随机输入,所以得到了黑洞。我已经设法通过了这个,但我知道我的做法是错误的,希望有人可以帮助我以正确的方式做到这一点。

然后,一旦我在控制器中有这个数据数组,我不知道如何正确地将它保存到数据库。

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:3)

只是做你正在做的事情,但在重复中,使用$ this-&gt; Form-&gt;输入而不是仅手动编写HTML。