您的位置:首页 > 编程语言 > PHP开发

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,

),

));

就好了!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: