当前位置: 首页 > news >正文

关于Yii中CGridView关联表字段的filter问题解决方法

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

当你想用CGridView控件来生成一个Grid表格的时候,是非常方便的,你只需要简单的指定几个属性就可以了,比如:
 

$this->widget('zii.widgets.CGridView', array(
  'id'=>'order-grid-view',
  'dataProvider'=>$model->search(),
  'filter'=>$model,
  'columns'=>array(
    'id',
    'customer_cd'
  ),
  )

关于Yii中CGridView关联表字段的filter问题解决方法

 问题是,当你需要多多表进行查询的时候,filter就需要多作一点工作了,很遗憾,我没有找到Yii官方对此问题的简易方法,所以,只能靠迂回的方式了。
首先,让关联表字段显示在Grid表格里面很容易,你可以在dataProvider属性加上关联表,然后columns属性里直接加上要显示的关联表属性就可以,比如,修改后的dataProvider为
'dataProvider'=>$model->with('relationNameToOtherTable')->search(),
修改后的columns属性为:
'columns'=>array(
    'id',
    'customer_cd',
    'customer_nm'=>array(
        'name'=>'relationNameToOtherTable.customer_nm',
    ),
),
但这时的customer_nm是不具备filter域的

解决方法如下:(修改主表对应的Model类)
1)手动为主表增加关联表属性,public $this->customer_nm;
2) 修改search()方法,增加如下两行:$criteria->with = 'relationNameToOtherTable';//relationNameToOtherTable是你在relations里面定义的键值
$criteria->compare('customer_nm', $this->customer_nm);
3)增加afterFind()方法到主表的model类,方法内容如下:$this->customer_nm = $this->relationNameToOtherTable->customer_nm;

这时,你就可以不像前面写的那样修改dataProvider和columns了,因为你手动增加的那个属性已经把关联表的字段属性加进来了,直接用就可以了,最终view代码如下:
'dataProvider'=>$model->search();
'columns'=>array(
    'id',
    'customer_cd',
    'customer_nm'=>array(
        'name'=>'relationNameToOtherTable.customer_nm',
    ),
),

ok, that's all, not the best solution, but it works any way, well if you have some good ideas for this kind of problem feel free to tell me, thanks a lot!!


转载于:https://my.oschina.net/u/148605/blog/289867

相关文章:

  • 78. Subsets
  • 如何识别一个字符串是否Json格式
  • 全能App研发助手!滴滴开源DoraemonKit
  • 码农张的Bug人生 - 初来乍到
  • cesiumjs开发实践(四) 地形介绍
  • Linux的文件管理类命令
  • java android 将小数度数转换为度分秒格式
  • [译] React v16.8: 含有Hooks的版本
  • sping 面向切面编程之引入通知
  • 自定义标签简介
  • 一张图知道HTML5布局(图)
  • 七牛云假注销小指南
  • Shell在大数据时代的魅力:从一道百度大数据面试题想到的点滴
  • CentOS7简单部署NFS
  • Axis2发布webservice(1)--0配置发布
  • SegmentFault for Android 3.0 发布
  • 【391天】每日项目总结系列128(2018.03.03)
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • CSS魔法堂:Absolute Positioning就这个样
  • Java 多线程编程之:notify 和 wait 用法
  • k个最大的数及变种小结
  • quasar-framework cnodejs社区
  • Sass Day-01
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • Twitter赢在开放,三年创造奇迹
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 基于Volley网络库实现加载多种网络图片(包括GIF动态图片、圆形图片、普通图片)...
  • 极限编程 (Extreme Programming) - 发布计划 (Release Planning)
  • 漫谈开发设计中的一些“原则”及“设计哲学”
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • Spark2.4.0源码分析之WorldCount 默认shuffling并行度为200(九) ...
  • ​软考-高级-信息系统项目管理师教程 第四版【第23章-组织通用管理-思维导图】​
  • #{}和${}的区别?
  • #常见电池型号介绍 常见电池尺寸是多少【详解】
  • (done) 两个矩阵 “相似” 是什么意思?
  • (java)关于Thread的挂起和恢复
  • (阿里云万网)-域名注册购买实名流程
  • (第8天)保姆级 PL/SQL Developer 安装与配置
  • (翻译)terry crowley: 写给程序员
  • (三十五)大数据实战——Superset可视化平台搭建
  • (一)Dubbo快速入门、介绍、使用
  • (一)spring cloud微服务分布式云架构 - Spring Cloud简介
  • (转)创业的注意事项
  • (转载)CentOS查看系统信息|CentOS查看命令
  • (轉)JSON.stringify 语法实例讲解
  • (状压dp)uva 10817 Headmaster's Headache
  • .NET 8.0 发布到 IIS
  • .NET 服务 ServiceController
  • .NET 设计一套高性能的弱事件机制
  • .NET 线程 Thread 进程 Process、线程池 pool、Invoke、begininvoke、异步回调
  • .net6使用Sejil可视化日志
  • .net开发引用程序集提示没有强名称的解决办法
  • .NET使用存储过程实现对数据库的增删改查
  • .Net语言中的StringBuilder:入门到精通
  • .Net中的集合