EasyUI加載完Html內容樣式渲染完成后顯示
714
2024-02-24
GridView 兩表聯查/搜索/分頁
當我們在一個網格視圖中顯示活動數據的時候,你可能會遇到這種情況,就是顯示關聯表的列的值,為了使關聯列能夠排序,你需要連接關系表,以及添加排序規則到數據提供者的排序組件中,對數據進行搜索,排序。
Ⅰ.控制器層Controller
<?php namespace backendcontrollers; header("Content-type:text/html;charset=utf-8"); use Yii; use yiiwebController; //超級控制器類 use backendmodelsBooksInfo; //表Model類 use backendmodelsInfoSearch; //引入搜索Model類 use yiidataActiveDataProvider; //小部件數據源類 use yiigridGridView; //查詢小部件 /** *@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 backendmodels; use Yii; use yiidbActiveRecord; /** *@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 backendmodels; //命名空間 use Yii; use yiibaseModel; //引入基類Model use yiidataActiveDataProvider; //引入數據源類 /** *@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 yiigridGridView; use yiidataActiveDataProvider; use yiigridActionColumn; use yiihelpersHtml; $this->title = '圖書列表'; ?> < 面包屑 --> <ol class="breadcrumb"> <li><a rel="external nofollow" rel="external nofollow" >Home</a></li> <li><a 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' => 'yiigridCheckboxColumn'], //復選框列 ['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' => 'yiigridActionColumn','header'=>'操作'], //動作列 ], 'pager' => [//自定義分頁樣式以及顯示內容 'prevPageLabel'=>'上一頁', 'nextPageLabel'=>'下一頁', 'firstPageLabel' => '第一頁', 'lastPageLabel' => '最后一頁', 'options'=>['style'=>'margin-left:200px;','class'=>"pagination"], ], ]); ?>
Ⅴ.效果展示
總結
以上所述是小編給大家介紹的Yii2.0小部件GridView(兩表聯查/搜索/分頁)功能的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對綠夏網網站的支持!
#免責聲明#
本站[綠夏技術導航]提供的一切軟件、教程和內容信息僅限用于學習和研究目的;不得將上述內容用于商業或者非法用途,否則,一切后果請用戶自負。本站信息來自網絡收集整理,版權爭議與本站無關。您必須在下載后的24個小時之內,從您的電腦或手機中徹底刪除上述內容。如果您喜歡該程序或內容,請支持正版,購買注冊,得到更好的正版服務。我們非常重視版權問題,如有侵權請郵件[admin@lxwl520.com]與我們聯系進行刪除處理。敬請諒解!