侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Yii2.0小部件GridView(两表联查/搜索/分页)功能的实现代码

框架(架构)  /  管理员 发布于 7年前   197

 GridView 两表联查/搜索/分页

当我们在一个网格视图中显示活动数据的时候,你可能会遇到这种情况,就是显示关联表的列的值,为了使关联列能够排序,你需要连接关系表,以及添加排序规则到数据提供者的排序组件中,对数据进行搜索,排序。

Ⅰ.控制器层Controller

 *@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

 *@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

 */// 注意:此处继承的是查询Model--->BooksInfoclass 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

title = '图书列表';?>
  1. Home
  2. 图书信息
  3. 图书列表
$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"], ],]);?>

Ⅴ.效果展示

总结

以上所述是小编给大家介绍的Yii2.0小部件GridView(两表联查/搜索/分页)功能的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!

您可能感兴趣的文章:

  • Yii分页用法实例详解
  • Yii使用CLinkPager分页实例详解
  • Yii2分页的使用及其扩展方法详解
  • Yii列表定义与使用分页方法小结(3种方法)
  • 详解Yii实现分页的两种方法
  • yii2分页之实现跳转到具体某页的实例代码
  • yii使用bootstrap分页样式的实例
  • Yii框架分页实现方法详解
  • Yii框架结合sphinx,Ajax实现搜索分页功能示例
  • YII框架中搜索分页jQuery写法详解
  • Yii 2.0实现联表查询加搜索分页的方法示例
  • yii框架使用分页的方法分析


  • 上一条:
    Yii2框架可逆加密简单实现方法
    下一条:
    Yii2框架之ListView小部件的使用方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Filament v3.1版本发布(0个评论)
    • docker + gitea搭建一个git服务器流程步骤(0个评论)
    • websocket的三种架构方式使用优缺点浅析(0个评论)
    • ubuntu20.4系统中宿主机安装nginx服务,docker容器中安装php8.2实现运行laravel10框架网站(0个评论)
    • phpstudy_pro(小皮面板)中安装最新php8.2.9版本流程步骤(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2018-05
    • 2020-02
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-11
    • 2021-03
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-08
    • 2023-08
    • 2023-10
    • 2023-12
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客