久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Yii2.0小部件GridView(兩表聯查/搜索/分頁)功能的實現代碼

這篇文章主要介紹了Yii2.0小部件GridView(兩表聯查/搜索/分頁)功能的實現代碼,需要的朋友可以參考下

 GridView 兩表聯查/搜索/分頁

當我們在一個網格視圖中顯示活動數據的時候,你可能會遇到這種情況,就是顯示關聯表的列的值,為了使關聯列能夠排序,你需要連接關系表,以及添加排序規則到數據提供者的排序組件中,對數據進行搜索,排序。

Ⅰ.控制器層Controller

<?php 
namespace backend\controllers;
header("Content-type:text/html;charset=utf-8");
use Yii;
use yii\web\Controller; //超級控制器類
use backend\models\BooksInfo; //表Model類
use backend\models\InfoSearch; //引入搜索Model類
use yii\data\ActiveDataProvider; //小部件數據源類
use yii\grid\GridView; //查詢小部件
/**
 *@abstract BooksController
 *@author NING <[email ning@163.com]>
 *@version [version 1.0] [書籍管理]
 */
class BooksInfoController extends Controller
{
 
 //書籍列表
 public function actionIndex()
 {
 $searchModel = new InfoSearch(); //實例化searchModel[搜索Model]
 if(!empty($_GET['InfoSearch'])){
  $getSearch = Yii::$app->request->get(); //接收搜索字段
  $data = $searchModel->search($getSearch);
 }else{
  //小部件查詢數據
  $data = new ActiveDataProvider([
    'query' => BooksInfo::find(), //查詢數據
    'pagination' => [
      'pageSize' => 2, //每頁顯示條數
    ],
    'sort' => [
      'defaultOrder' => [
        // 'created_at' => SORT_DESC,
        'id' => SORT_ASC, //[字段]設置排序·
      ]
    ],
  ]);
 }
 //傳送查詢數據、搜素Model
 return $this->render('index',['data'=>$data,'searchModel'=>$searchModel]);
 }
?>

Ⅱ.查詢模型層Model

<?php 
namespace backend\models;
use Yii;
use yii\db\ActiveRecord;
/**
 *@abstract [BookForm]
 *@author NING <[email ning@163.com]>
 *@version [vector 1.0] [書籍詳情模型]
 */
class BooksInfo extends ActiveRecord
{
 /**
   * @設置表名
   */
  public static function tableName()
  {
    return '{{%books_info}}';
  }
  //關聯表
  public function getBooksType(){
    // hasOne要求返回兩個參數 第一個參數是關聯表的類名 第二個參數是兩張表的關聯關系 
    // 這里id是books_type表的id, 關聯books_info表的type_id 
    return $this->hasOne(BooksType::className(), ['id' => 'type_id']);
  }
 public function attributeLabels()
 {
 return [
  'id' => 'ID',
  'book_name' => '書籍名稱',
  'book_face' => '書籍封面',
  'type_id' => '書籍分類ID',
  'type_name' => '書籍分類',
 ];
 }
}
?>

Ⅲ.搜索模型層Search

<?php
namespace backend\models; //命名空間
use Yii;
use yii\base\Model; //引入基類Model
use yii\data\ActiveDataProvider;  //引入數據源類
/**
 *@abstract [搜索Model]
 *@return [type]
 *@author NING <[email ning@163.com]>
 */
// 注意:此處繼承的是查詢Model--->BooksInfo
class InfoSearch extends BooksInfo
{
  public $type_name; //定義屬性變量
  // 只有在 rules() 函數中聲明的字段才可以搜索
  public function rules()
  {
    return [
      // [['book_name','type_name'], 'safe'],
      [['type_name'], 'safe'],
    ];
  }
  public function scenarios()
  {
    // 旁路在父類中實現的 scenarios() 函數
    return Model::scenarios();
  }
  public function search($params)
  {
    $query = BooksInfo::find();
    $dataProvider = new ActiveDataProvider([
      'query' => $query,
      'pagination' => [
        'pageSize' => 1,
      ],
    ]);
    /*這里的articlecategory是article模型里面關聯的方法名,除了首字母,其他都要完全一樣,否則會報錯*/
    $query->joinWith(['booksType']);
    // 從參數的數據中加載過濾條件,并驗證
    if (!($this->load($params) && $this->validate())) {
      return $dataProvider;
    }
    // 增加過濾條件來調整查詢對象
    $query->andFilterWhere(['like', 'book_name', $this->book_name]);
    //添加關聯字段過濾條件[注意:此處books_type.type_name中books_type為分類表名]
    $query->andFilterWhere(['like', 'books_type.type_name', $this->type_name]);
    return $dataProvider;
  }
}
?>

Ⅳ.視圖層View

<?php 
use yii\grid\GridView;
use yii\data\ActiveDataProvider;
use yii\grid\ActionColumn;
use yii\helpers\Html;
$this->title = '圖書列表';
?>
<!-- 面包屑 -->
<ol class="breadcrumb">
 <li><a href="#" rel="external nofollow" rel="external nofollow" >Home</a></li>
 <li><a href="#" rel="external nofollow" rel="external nofollow" >圖書信息</a></li>
 <li class="active">圖書列表</li>
</ol>
<?php
echo GridView::widget([
 'dataProvider' => $data,  //數據源
  'filterModel' => $searchModel, //搜索列
 'columns' => [
    // ['filterModel' => $searchModel],
    ['class' => 'yii\grid\CheckboxColumn'], //復選框列
    ['attribute' => 'id'],
   ['attribute' => 'book_name',],
    ['attribute' => 'book_face','content'=>function($model){
     // 圖片顯示
     return Html::img($model->book_face,['width'=>'50']);
    }],
 [
      'attribute' => 'type_name',
      'value' => 'booksType.type_name', //兩表聯查[書籍類型]
    ],
    ['class' => 'yii\grid\ActionColumn','header'=>'操作'], //動作列
 ],
  'pager' => [//自定義分頁樣式以及顯示內容
    'prevPageLabel'=>'上一頁',
    'nextPageLabel'=>'下一頁',
    'firstPageLabel' => '第一頁',
    'lastPageLabel' => '最后一頁',
    'options'=>['style'=>'margin-left:200px;','class'=>"pagination"],
    ],
]);
?>
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了Yii2.0實現生成二維碼功能,結合實例形式分析了Yii2.0框架生成二維碼所涉及的相關擴展引入步驟與使用方法,需要的朋友可以參考下
本篇文章主要介紹了yii2.0整合阿里云oss的示例代碼,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了yii2.0整合阿里云oss刪除單個文件的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章主要介紹了Yii2.0使用阿里云OSS的SDK上傳圖片、下載、刪除圖片示例,具有一定的參考價值,有興趣的可以了解一下
這篇文章主要為大家詳細介紹了Yii2之ListView小部件的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
這篇文章主要給大家介紹了關于利用Yii 2.0實現聯表查詢加搜索分頁的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來跟
主站蜘蛛池模板: www.日本精品 | 91精品在线播放 | 在线日韩欧美 | 成人亚洲精品 | 亚洲成人精品在线 | 欧美亚洲国产成人 | 九九看片 | 6996成人影院网在线播放 | 91黄在线观看 | 成人欧美一区二区 | 欧美日韩视频在线播放 | 七七婷婷婷婷精品国产 | 中文字幕免费视频 | 日韩欧美三区 | 久久网一区二区三区 | 国产成人精品一区二区三区四区 | 激情综合五月 | 国产美女视频黄a视频免费 国产精品福利视频 | 爱爱小视频| 亚洲精品免费视频 | 99国产精品99久久久久久粉嫩 | 精品视频在线播放 | 国产欧美久久一区二区三区 | 亚洲精品久久久 | 亚洲精品电影网在线观看 | 天堂在线中文 | 国产精品精品视频一区二区三区 | 国产精品一区二区免费 | 久久99精品国产自在现线小黄鸭 | 日韩一区二区三区视频在线播放 | 日日躁狠狠躁aaaaxxxx | 一区二区视频在线 | 一级毛片,一级毛片 | 91视频一区二区 | 中文字幕电影在线观看 | 国产粉嫩尤物极品99综合精品 | 国产高清一区二区三区 | 欧美伊人久久久久久久久影院 | 国产主播第一页 | 国产精品我不卡 | 欧美aaaaaaaa |