濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > YII2框架中ActiveDataProvider與GridView的配合使用操作示例

YII2框架中ActiveDataProvider與GridView的配合使用操作示例

熱門標(biāo)簽:南寧電話外呼系統(tǒng)線路 咸陽(yáng)電銷 南京3D地圖標(biāo)注 嘟嘟云外呼系統(tǒng) 辦理400電話哪家好點(diǎn) 正規(guī)電銷機(jī)器人系統(tǒng) 邢臺(tái)400電話辦理 重慶外呼電銷系統(tǒng)多少錢 濟(jì)源百應(yīng)電銷機(jī)器人聯(lián)系方式

本文實(shí)例講述了YII2框架中ActiveDataProvider與GridView的配合使用操作。分享給大家供大家參考,具體如下:

YII2中ActiveDataProvider可以使用yii\db\Query或yii\db\ActiveQuery的對(duì)象,方便我們構(gòu)造復(fù)雜的查詢篩選語(yǔ)句。

配合強(qiáng)大的GridView,快速的顯示我們想要的數(shù)據(jù)。

通過(guò)上面的兩個(gè)工具,我們快速的顯示用戶表信息。用戶表結(jié)構(gòu)如下:

我們創(chuàng)建一個(gè)用戶模型MyUser.php,代碼如下:

?php

namespace app\models;

use yii\db\ActiveRecord;
use yii\data\ActiveDataProvider;

class MyUser extends ActiveRecord
{

  //返回要操作的表名
  public static function tableName()
  {
    return '{{%user}}';
  }

  //設(shè)置規(guī)則
  //注意,如果沒有給字段設(shè)置規(guī)則,GridView的篩選項(xiàng)是不會(huì)出現(xiàn)的
  public function rules()
  {
    return [
      [['id', 'name', 'sex', 'age'], 'trim'],
      [['id', 'sex', 'age'], 'integer'],
      ['name', 'string'],
    ];
  }

  //查詢
  public function search($params)
  {
    //首先我們先獲取一個(gè)ActiveQuery
    $query = self::find();
    //然后創(chuàng)建一個(gè)ActiveDataProvider對(duì)象
    $provider = new ActiveDataProvider([
      //為ActiveDataProvider對(duì)象提供一個(gè)查詢對(duì)象
      'query' => $query,
      //設(shè)置分頁(yè)參數(shù)
      'pagination' => [
        //分頁(yè)大小
        'pageSize' => 3,
        //設(shè)置地址欄當(dāng)前頁(yè)數(shù)參數(shù)名
        'pageParam' => 'p',
        //設(shè)置地址欄分頁(yè)大小參數(shù)名
        'pageSizeParam' => 'pageSize',
      ],
      //設(shè)置排序
      'sort' => [
        //默認(rèn)排序方式
        'defaultOrder' => [
          'id' => SORT_DESC,
        ],
        //參與排序的字段
        'attributes' => [
          'id', 'name', 'sex', 'age'
        ],
      ],
    ]);

    //如果驗(yàn)證沒通過(guò),直接返回
    if (!($this->load($params)  $this->validate())) {
      return $provider;
    }

    //增加過(guò)濾條件
    $query->andFilterWhere(['id' => $this->id])
      ->andFilterWhere(['like', 'name', $this->name])
      ->andFilterWhere(['sex' => $this->sex])
      ->andFilterWhere(['age' => $this->age]);

    return $provider;
  }
}

然后,創(chuàng)建控制器TestController.php,代碼如下:

?php

namespace app\controllers;

use YII;
use yii\web\Controller;
use app\models\MyUser;

class TestController extends Controller
{
  public function actionTest()
  {

    $user = new MyUser();
    //調(diào)用模型search方法,把get參數(shù)傳進(jìn)去
    $provider = $user->search(YII::$app->request->get());

    return $this->render('test', [
      'model' => $user,
      'provider' => $provider,
    ]);
  }
}

視圖頁(yè)面test.php,代碼如下:

?php
use yii\helpers\Url;
use yii\helpers\Html;
use yii\grid\GridView;
?>

div id="page-wrapper">
  div class="row">
    div class="col-lg-12">
      button class="btn btn-primary" id="showSelBtn">顯示我選中的/button>
    /div>
  /div>
  div class="row">
    div class="col-lg-12">
      ?php echo GridView::widget([
        //設(shè)置GridView的ID
        'id' => 'myUserGridView',
        //設(shè)置數(shù)據(jù)提供器
        'dataProvider' => $provider,
        //設(shè)置篩選模型
        'filterModel' => $model,
        'columns' => [
          //復(fù)選框列
          ['class' => 'yii\grid\CheckboxColumn'],
          //顯示序號(hào)列
          ['class' => 'yii\grid\SerialColumn'],
          [
            //設(shè)置字段顯示標(biāo)題
            'label' => 'ID',
            //字段名
            'attribute' => 'id',
            //格式化
            'format' => 'raw',
            //設(shè)置單元格樣式
            'headerOptions' => [
              'style' => 'width:120px;',
            ],
          ],
          [
            'label' => '姓名',
            'attribute' => 'name',
            'format' => 'raw',
          ],
          [
            'label' => '頭像',
            'attribute' => 'head_img',
            'format' => 'raw',
            //通過(guò)該返回值,我們可以任意控制列數(shù)據(jù)的顯示
            //$data指向的是當(dāng)前行的數(shù)據(jù)結(jié)果集
            'value' => function ($data) {
              return 'img src="' . '/' . ltrim($data->head_img, '/') . '" width="60px">';
            },
          ],
          [
            'label' => '性別',
            //設(shè)置篩選選項(xiàng)
            'filter' => [0 => '男', 1 => '女'],
            'attribute' => 'sex',
            'format' => 'raw',
            'value' => function ($data) {
              return ($data->sex == 0) ? '男' : '女';
            }
          ],
          [
            'label' => '年齡',
            'attribute' => 'age',
            'format' => 'raw',
          ],
          [
            'header' => '操作',
            'class' => 'yii\grid\ActionColumn',
            //設(shè)置顯示模板
            'template' => '{upd} {del}',
            //下面的按鈕設(shè)置,與上面的模板設(shè)置相關(guān)聯(lián)
            'buttons' => [
              'upd' => function ($url, $model, $key) {
                return 'a href="' . Url::toRoute(['test/upd', 'id' => $key]) . '" rel="external nofollow" class="btn btn-warning">修改/a>';
              },
              'del' => function ($url, $model, $key) {
                return 'a href="' . Url::toRoute(['test/del', 'id' => $key]) . '" rel="external nofollow" class="btn btn-danger">刪除/a>';
              },
            ],
          ],
        ],
      ]); ?>
    /div>
  /div>
/div>

?php echo Html::jsFile('@web/js/jquery-3.3.1.min.js'); ?>
script type="text/javascript">
  $("#showSelBtn").on("click", function () {
    var keys = $("#myUserGridView").yiiGridView('getSelectedRows');
    alert(keys);
  });
/script>

顯示結(jié)果如下:

更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • Yii中CArrayDataProvider和CActiveDataProvider區(qū)別實(shí)例分析
  • 淺析Yii2中GridView常見操作
  • yii2.0之GridView自定義按鈕和鏈接用法
  • Yii2 GridView實(shí)現(xiàn)列表頁(yè)直接修改數(shù)據(jù)的方法
  • 淺析Yii2 gridview實(shí)現(xiàn)批量刪除教程
  • 淺析Yii2 GridView實(shí)現(xiàn)下拉搜索教程
  • 淺析Yii2 GridView 日期格式化并實(shí)現(xiàn)日期可搜索教程
  • yii2使用GridView實(shí)現(xiàn)數(shù)據(jù)全選及批量刪除按鈕示例
  • yii2中結(jié)合gridview如何使用modal彈窗實(shí)例代碼詳解
  • yii2使用gridView實(shí)現(xiàn)下拉列表篩選數(shù)據(jù)
  • Yii2.0小部件GridView(兩表聯(lián)查/搜索/分頁(yè))功能的實(shí)現(xiàn)代碼
  • yii2-GridView在開發(fā)中常用的功能及技巧總結(jié)

標(biāo)簽:通遼 南通 河南 唐山 隴南 黃山 武漢 平頂山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《YII2框架中ActiveDataProvider與GridView的配合使用操作示例》,本文關(guān)鍵詞  YII2,框架,中,ActiveDataProvider,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《YII2框架中ActiveDataProvider與GridView的配合使用操作示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于YII2框架中ActiveDataProvider與GridView的配合使用操作示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    松桃| 许昌县| 东源县| 古交市| 兴宁市| 德兴市| 漳平市| 东阿县| 民勤县| 罗平县| 乌鲁木齐县| 肃北| 万载县| 华安县| 渑池县| 巴楚县| 磐安县| 高碑店市| 安溪县| 英吉沙县| 睢宁县| 奉贤区| 来安县| 柞水县| 靖远县| 抚宁县| 黑河市| 綦江县| 灵璧县| 佛教| 徐水县| 田林县| 蓬莱市| 花莲市| 宜章县| 曲水县| 武城县| 石河子市| 淮北市| 柳州市| 健康|