在自定义组件的站点视图中访问通过外键链接的数据



在我的自定义组件中,在站点视图中,我有一个国家/地区列表(查看:国家/地区)。单击一个国家/地区,将显示另一个视图(视图:人员),显示居住在该国家/地区的所有人。

现在,在人物视图中,我想显示国家的名称和国旗。

所以我想在...site/models/persons.php中添加一个function getCountry()

public function getCountry() {
    $db = $this->getDBO(); 
    $id = $this->state->get("filter.country");
    $sql = "SELECT * FROM #__cnlp_persons_country WHERE id = $id";
    $db->setQuery($sql); 
    $country = $db->loadResult(); 
    // var_dump($country);
    return $country; 
}

然后,我添加到.../site/views/persons/view.html.php

class Cnlp_personsViewPersons extends JView
{
    protected $items;
    protected $state;
    protected $params;
    protected $country; // <--- I added this
    ...
    public function display($tpl = null)
{
        $app                = JFactory::getApplication();
        $this->state        = $this->get('State');
        $this->items        = $this->get('Items');
        $this->params               = $app->getParams('com_cnlp_trainers');
        $this->country              = $this->get('Country'); // <--- I added this
        (...)

结果:我想我可以---/site/views/persons/tmpl/default.php类似的东西......

<h1><?php echo $this->country->name; ?></h1>
<img src="<?php echo $this->country->flag; ?>" />

。但我没有得到输出...我做错了什么?

$db->loadResult();用于

加载单个值结果(例如,如果您只想选择国家/地区名称或类似的东西),但在查询中您选择的是整行,因此您应该使用以下之一:

$db->loadRow(); // returns an indexed array from a single record in the table
$db->loadAssoc(); // returns an associated array from a single record in the table
$db->loadObject(); // returns a PHP object from a single record in the table:

你可以在这里阅读更多关于这个的信息(这是joomla 1.5文档,但2.5和3是一样的)

相关内容

  • 没有找到相关文章

最新更新