如何解决cakePHP-为模型或控制器添加新功能
| 我是CakePHP和MVC开发的新手,正在尝试用CakePHP创建一些东西,但无法弄清楚该如何做: 我正在创建一个简单的CRUD应用程序,该应用程序通过简单的数据输入表单来接收专辑和歌曲。我创建了数据库,并使用Cake控制台应用程序创建了所有模型/控制器等,并且效果很好。我可以毫无问题地收录专辑和歌曲,并且数据库中的歌曲表通过外键连接到专辑表,因此模型中的所有链接和关联都在那里。 我想要做的是能够单击某个专辑并查看与该专辑相关的歌曲,但是我不确定该如何处理。我需要在模型中添加查询,还是该功能进入Controller? 我的看法是:在相册列表中,建立相册名称链接,该链接称为| viewAlbum |。在Songs Controller中具有专辑ID的功能。虽然不确定从这里去哪里...... 谁能指出我正确的方向? 干杯, 科姆 @JohnP谢谢您的答复。但是,如何创建链接以在控制器中调用该函数呢?我有 :echo $html->link(__($album[\'Album\'][\'title\'],true),array(\'controller\'=>\'Songs\',\'action\'=>\'viewAlbum\',$album[\'Album\'][\'id\']));
其中viewAlbum是Songs控制器中函数的名称。有什么想法为什么不起作用?
解决方法
原始人-
如果我的理解正确-您正在使用John的示例,并且需要在视图中修复调用其控制器的链接?
<?
echo $this->Html->link(__($album[\'Album\'][\'title\'],true),array(\'controller\'=>\'Album\',\'action\'=>\'viewSongs\',$id));
?>
John的示例说明了如何在Albums控制器中创建方法,建议在Songs模型中点击一个方法以返回所需的结果。
因此,您的链接将定位到Album控制器,并且其动作应为controller方法。
该方法在Songs控制器中意义不大,因为它需要一个专辑ID。您只希望专辑控制器从Songs模型/表中提取关联的数据。 John的答案是完全正确的,但如果您刚开始使用Cake,它可能太复杂了。 John通过在Song模型中放置一个方法(由Albums控制器中的方法调用)来拆分所需的功能,该方法为视图显示拉取结果。
我将其切换为“胖控制器”,短代码更容易遵循,但MVC更少。
您需要从专辑到歌曲的hasMany关系-每个专辑都有多首歌曲:
// ../models/album.php
class Album extends AppModel {
var $name = \'Album\';
var $hasMany = array(
\'Song\' => array(
\'className\' => \'Song\',\'foreignKey\' => \'album_id\'
)
);
您的控制器动作将如下所示:
// ../controllers/albums_controller.php
function viewSongs($id = null) {
if(isset($id) && $id != null) {
$albums = $this->Album->find(\'first\',array(\'conditions\'=>array(\'Album.id\'=>$id));
$songs = $this->Album->Song->find(\'all\',array(\'conditions\'=>array(\'Song.album_id\'=>$id)));
// This returns variables to the view to use
$this->set(compact(\'albums\',\'songs\'));
}
}
您的视图将称为viewSongs.ctp,它看起来像这样:
// ../views/albums/viewSongs.ctp
<?php
foreach($albums as $album) {
echo \"<h2>{$album[\'name\']}</h2>\";
echo \"<ul>\";
foreach ($songs as $song) {
echo \"<li>{$song[\'Song\'][\'name\']}</li>\"
}
echo \"</ul>\";
}
您在../views/albums/view.ctp中的链接将类似于:
<?php
echo $this->Html->link(\'View Songs\',array(\'controller\'=>\'albums\',$id));
?>
, Cake \的本地ORM已经为您完成了此任务。如果您确实进入了专辑的查看页面,它应该在其中显示所有与之相关的歌曲。仅当您正确设置了关系后,此方法才有效。
如果要自己编写此行为的代码,则可以在AlbumController中放置一个viewSongs
动作。该方法将查看传递给它的专辑ID,然后在您的Song模型中调用一个方法(例如getSongsByAlbum($aid)
)。在您的歌曲模型中的该方法内部将是一个看起来像这样的调用
$opts = array(
\'conditions\' => array(
\'album_id\' => $aid
)
);
return $this->find(\'all\',$opts);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。