Yii2 在 gridview 行中显示多个图像

Yii2 display multiple images in gridview row

我想在 gridviews 的单行中显示多个图像。例如:我有 table A,Table B 和 table C.

Table A has my_id.

In Table B my_id is the foreign key. Along with my_id it has c_id.

Table C has c_id which is in reference in Table B.

Table C also has a filepath to display images.

Table A 我有 my_id 如下: 1、2、3、4、5、6。

Table B 我有 my_id 如下。 1 ,1 ,1 ,2 ,3, 3.

Table B中我还有c_id如下。 1、2、3、4、5、6。

在 table C 中,我的 c_id 是: 1, 2, 3, 4, 5, 6. 这些 id 都有与它们每个相关联的文件路径。它们是不同的图像。

由于外键限制,现在我的 gridview 应该为 my_id 显示 3 个不同的图像。但它只显示 1 张图片。

我的代码如下:

在我的模型中

 public function getPictogramsID()
{
    $pictogramsID = SdsrefGhsPictograms::find()->where(['sdsref_id' => $this->sdsref_id])->all();
    foreach ($pictogramsID as $picID){
        return $picID->pictogram_id;
    }
}



 public function getPictogramPath()
{


     $pictogramsID = GhsPictogram::find()->where(['pictogram_id' => $this->getPictogramsID()])->all();
    foreach ($pictogramsID as $picID){
        $pic = $picID->pictogram_filepath;
    }
    return $pic;

}



public function getPictogramUrl()
{

    //var_dump($this->getPictogramPath()); exit();
    return \Yii::$app->request->BaseUrl.'/web'.$this->getPictogramPath()  ;
}

我的索引文件网格视图图像代码

 [
        'label' => 'Hazards',  
        'format' => 'raw',   
        'value' => function ($data) {
                return Html::img($data->getPictogramUrl(), ['alt'=>'myImage','width'=>'20','height'=>'30']); 
            },
        ],   

我也在尝试为此添加一个 bootstrap 工具提示。工具提示显示成功,但我认为循环没有以正确的方式完成,所以它正在重复我的图像。

这是我更新的 gridview 代码。

 [
        'label' => 'Hazards',  
        'format' => 'raw',   
        'value' => function ($data) {
             $images = '';

    // append all images
            foreach($data->getPictogramName() as $name)     
                foreach ($data->getPictogramUrl() as $url)                   
                $images = $images.Html::img($url,['alt'=>'','width'=>'30','height'=>'30', 'data-toggle'=>'tooltip','data-placement'=>'left','title' => $name ,'style'=>'cursor:default;']);
            return $images;

        }
        ],

您在模型和网格视图中几乎没有逻辑错误。在所有这些领域中,您处理的是一项而不是三项。

在你的模型中

 public function getPictogramsID()
 {   
    $ids = [];
    $pictogramsID = SdsrefGhsPictograms::find()->where(['sdsref_id' => $this->sdsref_id])->all();
    foreach ($pictogramsID as $picID){
       $ids[] =  $picID->pictogram_id;
    }

    return $ids;// returning all three ids
 }



 public function getPictogramPath()
 {

    $pic = [];
    $pictogramsID = GhsPictogram::find()->where(['pictogram_id' => $this->getPictogramsID()])->all();
    foreach ($pictogramsID as $picID){
        $pic[] = $picID->pictogram_filepath;
    }
    return $pic;

}



public function getPictogramUrl()
{
  $url = [];
  foreach($this->getPictogramPath() as $path):
       $url[] = \Yii::$app->request->BaseUrl.'/web'.$path; 
  endforeach;
  return $url; // returning al urls
}

现在您可以查看所有 url 的循环并在每个 url

中附加图像
[
    'label' => 'Hazards',  
    'format' => 'raw',   
    'value' => function ($data) {

        $images = '';
        // append all images
        foreach($data->getPictogramUrl() as $url):
            $images = $images.Html::img($url, ['alt'=>'myImage','width'=>'20','height'=>'30']);
        endforach; 
        return $images;
    },
],