> php教程 > PHP开发 > Yii의 행 아래 각 열의 데이터를 순회하는 방법

Yii의 행 아래 각 열의 데이터를 순회하는 방법

高洛峰
풀어 주다: 2016-12-20 15:12:36
원래의
1166명이 탐색했습니다.

이 문서의 예에서는 Yii가 행 아래 각 열의 데이터를 탐색하는 방법을 설명합니다. 참고용으로 모두와 공유하세요. 세부 사항은 다음과 같습니다.

렌더링은 다음과 같습니다.

Yii의 행 아래 각 열의 데이터를 순회하는 방법

컨트롤러(1종):

//显示列表
public function actionList()
{
    //实例化对象
    $model= new Qiu();
    $country = \Yii::$app->db;
    //查询数据
    $data = $country->createCommand("select * from qiu join region on qiu.region_id=region.region_id")->queryAll();
    $region_ids = $country->createCommand("select region_id from region")->queryAll();
    $region = $country->createCommand("select * from region")->queryAll();
    //遍历数组
    $ids = array();
    $names = array();
    $count = array();
    //遍历区域ID
    foreach ($region_ids as $key => $v)
    {
      $ids[$key] = $v['region_id'];
    }
    //print_r($ids);die;
    //遍历球队
    foreach ($ids as $key => $val)
    {
      $data =Qiu::find()->where(['region_id'=>$val])->asArray()->all();
      $count[]=count($data);
      $rows[$val] = $data;
    }
    //print_r($rows);die;
    //根据所有记录进行遍历,显示最多行数
    $ji = max($count);
    $arr = array();
    //找出对应的球队
    for($i=0;$i<$ji;$i++)
    {
      foreach($rows as $key => $val)
      {
        if(isset($val[$i]))
        {
          $arr[$i][$key] = $val[$i][&#39;q_name&#39;];
        }
        else
        {
          $arr[$i][$key] = &#39;&#39;;
        }
      }
    }
    //var_dump($arr);die;
    //分配数据
    return $this->render(&#39;list&#39;,[&#39;arr&#39;=>$arr,&#39;region&#39;=>$region]);
}
로그인 후 복사

(2종):

public function actionList1()
{
    //实例化模型层
    $region = new Region;
    $qiu = new Qiu;
    //取出区域表的iQiud和所有数据,队表数据
    $region_ids = $region->find()->select(&#39;region_id&#39;)->column();
    $areas = $region->find()->asArray()->all();
    $team = $qiu->find()->asArray()->all();
    $count = array();
    $info = array();
    foreach ($region_ids as $aid) {//1,2,3--6
      foreach ($team as $key=>$val) {
        if($val[&#39;region_id&#39;] == $aid){
          $info[$aid][] = $val;
          $count[]=count($info[$aid]);
        }
      }
    }
    //var_dump($count);die;
    $con = max($count);
    $arr = array();
    for ($i=0; $i <$con ; $i++) {
      foreach ($info as $key => $val) {
        if(isset($val[$i])){
          $arr[$i][$key] = $val[$i][&#39;q_name&#39;];
        } else {
          $arr[$i][$key] = &#39;&#39;;
        }
      }
    }
    //var_dump($arr);die;
    return $this->render(&#39;list&#39;,[&#39;arr&#39;=>$arr,&#39;region&#39;=>$areas]);
}
로그인 후 복사

뷰 레이어:

<table border="1">
<!--一行区域-->
<tr style="background:red;">
<?php foreach ($region as $key => $v1) {?>
<td><?php echo $v1[&#39;region_name&#39;]; ?></td>
<?php }?>
</tr>
<!--每列球队-->
<?php foreach ($arr as $key => $val) {?>
<tr>
<?php foreach ($val as $key => $v) {?>
<td><?php echo $v; ?></td>
<?php } ?>
</tr>
<?php } ?>
</table>
로그인 후 복사

이 글이 Yii 프레임워크를 기반으로 하는 모든 분들의 PHP 프로그램 설계에 도움이 되기를 바랍니다.

행 아래 각 열의 데이터를 탐색하는 Yii의 방법에 대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿