YII框架 CGridview显示字段上面加LINK

BY:蓝天白云(小T)

这个问题 我今天也搞了很长时间。终于给我找到解决的办法了.
比如:还是那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(            

'type'=>'raw',  
            '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,
            ),
        ));
就好了!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值