YII框架 CGridview显示字段上面加LINK
2011-08-31 19:59
387 查看
这个问题 我今天也搞了很长时间。终于给我找到解决的办法了.
比如:还是那2张表
url_info ; category
url_info 字段: id,cid ,title,url
category字段:id ,name
其中url_info.cid=category.id
目的:根据category的name 查出URL_INFO中相对应的URL
比如我有一个有 名字叫:魔兽世界 (也就是:category.name=魔兽世界),我想找出和魔兽世界相关系的网站,比如它的官网地址 下载地址等。
YII 框架其实很好了用的。只要你写出2个表的关系:
/**
* @return array relational rules.
*/
public function relations()
{
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array(
'category'=>array(self::BELONGS_TO, 'category', 'cid'),
);
}
显示层:
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
array( 'class'=>'CLinkColumn',
'header'=>'游戏类别名称',//显示表名称
'labelExpression'=>'$data->category_name',//显示名称
'urlExpression'=>'Yii::app()->createUrl("url_info",array("cid"=>$data->id))',//显示URL
//'linkHtmlOptions'=>array('title'=>'See all entries with this last name')
),
'category_style',
'sort_num',
array(
'class'=>'CButtonColumn',
),
),
其中我用到了YII框架中自带的CLinkColumn属性。
还有种办法:
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
array(
'name'=>'category_name',
'value'=>'CHtml::link($data->category_name,$url)',//名称和URL
),
'category_style',
'sort_num',
array(
'class'=>'CButtonColumn',
),
),
这种方法用的是CHtml::link()
然后只要在url_info的控制层中写出
$dataProvider=new CActiveDataProvider('url_info', array(
'criteria'=>array(
'condition'=>'cid=:id',
'params'=>array(':cid'=>$_GET['cid']),
'with'=>array('category'),
'order'=>'cid desc',
),
'pagination'=>array(
'pageSize'=>self::PAGE_SIZE,
),
));
就好了!
比如:还是那2张表
url_info ; category
url_info 字段: id,cid ,title,url
category字段:id ,name
其中url_info.cid=category.id
目的:根据category的name 查出URL_INFO中相对应的URL
比如我有一个有 名字叫:魔兽世界 (也就是:category.name=魔兽世界),我想找出和魔兽世界相关系的网站,比如它的官网地址 下载地址等。
YII 框架其实很好了用的。只要你写出2个表的关系:
/**
* @return array relational rules.
*/
public function relations()
{
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array(
'category'=>array(self::BELONGS_TO, 'category', 'cid'),
);
}
显示层:
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
array( 'class'=>'CLinkColumn',
'header'=>'游戏类别名称',//显示表名称
'labelExpression'=>'$data->category_name',//显示名称
'urlExpression'=>'Yii::app()->createUrl("url_info",array("cid"=>$data->id))',//显示URL
//'linkHtmlOptions'=>array('title'=>'See all entries with this last name')
),
'category_style',
'sort_num',
array(
'class'=>'CButtonColumn',
),
),
其中我用到了YII框架中自带的CLinkColumn属性。
还有种办法:
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
array(
'name'=>'category_name',
'value'=>'CHtml::link($data->category_name,$url)',//名称和URL
),
'category_style',
'sort_num',
array(
'class'=>'CButtonColumn',
),
),
这种方法用的是CHtml::link()
然后只要在url_info的控制层中写出
$dataProvider=new CActiveDataProvider('url_info', array(
'criteria'=>array(
'condition'=>'cid=:id',
'params'=>array(':cid'=>$_GET['cid']),
'with'=>array('category'),
'order'=>'cid desc',
),
'pagination'=>array(
'pageSize'=>self::PAGE_SIZE,
),
));
就好了!
相关文章推荐
- YII-在CGridview显示的字段上面加上带参数的链接
- Yii框架里用grid.CGridView调用pager扩展不显示最后一页按钮的解决
- PHP YII框架学习 按条件查询显示在YII自带的CGridView上
- Yii框架常见问题: CGridView关联表字段的filter问题解决
- 关于使用Yii框架开发时数据库增加字段后保存无效的问题
- Yii框架中CGridView的使用方法以及详细示例
- Yii框架中CGridView的使用方法
- Yii框架中CGridView的使用方法以及详细示例
- Yii框架中CGridView的使用方法以及详细示例
- 知乎上有一个问题“在mfc框架中,有上面方法能直接将opencv2.0库中的Mat格式图片传递到Picture Control”中显示?
- Yii框架中 find findAll 查找出制定的字段的方法对比
- ssm框架 里面查询列表,显示出来有字段漏掉(或者说少显示)
- Yii框架查询Mongodb并页面显示问题
- 关于Yii 中使用CArrayDataProvider的CGridview 没有办法去自定义列的显示的问题
- DWZ 框架remote 验证字段唯一性方法提交后台,如果是中文会显示成乱码问题
- Yii框架中 find findAll 查找出制定的字段的方法对比
- YII 框架 第八天(4) 显示sql语句执行时间
- Yii框架验证码不显示、不刷新、验证不正确的一些解决办法
- Yii: 如何在CGridView组件中根据不同的记录行数据显示不同的操作
- SharePoint 2013 中使用JSLink 来改变列表中某个字段或view(视图)的显示方式