圆般 2011-06-05 10:36:24 5985次浏览 2条回复 2 2 0

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

比如:还是那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,
            ),
));

就好了! 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/t240034137/archive/2010/03/05/5350319.aspx

其他代码提示

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider' => $dataProvider, //数据源
    'pager' => array(//通过pager设置样式   默认为CLinkPager
        'prevPageLabel' => '上一页',
        'firstPageLabel' => '首页', //first,last 在默认样式中为{display:none}及不显示,通过样式{display:inline}即可
        'nextPageLabel' => '下一页',
        'lastPageLabel' => '末页',
        'header' => '',
    ),
    'ajaxUpdate' => false, //是否使用ajax分页   null为ajax分页
    'columns' => array(
        array(//具体设置每列的header
            'name' => 'ID',
            'value' => '$data->id',
        ),
        'parentid',
        array(
            'name' => '标题', //需要连接可使用CLinkColumn
            'value' => '$data->title',
        ),
        array(
            'name' => '模型',
            'value' => '$data->module',
        ),
        array(//自定义按钮操作列
            'header' => '操作',
            'buttons' => array(
                'preview' => array(
                    'label' => '审核',
                    'url' => '', // 通过PHP表达式生成URL    例如createUrl
                    'imageUrl' => '', // 按钮图片地址
                    'options' => array(), // HTML 标签属性设置
                    'click' => '', // js 代码或函数
                    'visible' => '', // PHP表达式 用于权限控制
                ),
                'recommend' => array(
                    'label' => '推荐',
                ),
            ),
            'class' => 'CButtonColumn',
            'template' => '{preview}  {recommend}',
        ),
        array(//仅使用默认CButtonColumn不具体设置按钮,在显示为查看 修改 删除图片按钮
            'class' => 'CButtonColumn',
        ),
    ),
));
觉得很赞
您需要登录后才可以回复。登录 | 立即注册