Yii框架扩展CGridView增加导出CSV功能的方法
本文实例讲述了Yii框架扩展CGridView增加导出CSV功能的方法。分享给大家供大家参考,具体如下:
Yii提供的CGridView组件没有内置数据导出功能,不过我们可以通过扩展该组件来添加该功能。
具体方法如下:
1、首先派生一个子类,添加一个action成员,在该视图的init函数中判断是浏览动作还是数据导出动作,如果是浏览动作者则保持默认行为,否则输出csv文件。
public function init()
{
if($this->action == 'export')
{
parent::init();
$this->genCsv();
}
else
{
parent::init();
}
}
2、处理csv文件的输出:
protected function genCsv()
{
header("Content-Type: text/csv; charset=GB2312");
header('Content-Disposition: attachment; filename="'.$this->fileName.'"');
//add your content dump codes here
flush();
}
3、然后在表格控件界面上添加一个csv导出按钮
覆盖其renderItems()方法如下:
public function renderItems()
{
if(Yii::app()->user->checkAccess('administrator'))
{
echo '<div class="toolBar">';
echo '<form action="'.CHtml::normalizeUrl(array($this->action)).'&id='.$this->id.'" method="post">';
foreach($this->getController()->getActionParams() as $name => $value)
{
echo '<input type="hidden" name="'.addcslashes($name,'"').'" value="'.addcslashes($value,'"').'" />';
}
echo '<input type="image" title="'.Yii::t('ifCMS','Export to CSV').'" src="'.Yii::app()->theme->BaseUrl.'/images/ico-csv.png" alt="Submit">';
echo '</form>';
echo '</div>';
}
parent::renderItems();
}
4、然后在点击CSV的动作处理比如actionCsv()中render单个表格视图,模板如下
<?php
$this->widget('application.extensions.grid.MyGridView', array(
'id'=>'grid',
'action'=>'export',
'dataProvider'=>$dp,
'columns'=>array(
array(
'header'=>Yii::t('Statistics','Phone'),
'name'=>'phone',
),
array(
'header'=>Yii::t('Statistics','Count'),
'name'=>'count',
),
)
));?>
注意上述第2步csv输出函数中的header设置语句之前不要有任何的输出,包括如下函数:
print, echo, printf, trigger_error, vprintf, ob_flush, var_dump, readfile, passthru
否则内容只会在浏览器中输出,但不会出现文件下载。
更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
- Yii中使用PHPExcel导出Excel的方法
- Yii2框架中使用PHPExcel导出Excel文件的示例
- Yii框架使用PHPExcel导出Excel文件的方法分析【改进版】
- Yii Framework框架使用PHPExcel组件的方法示例
- YII2框架中excel表格导出的方法详解
- Yii安装与使用Excel扩展的方法
- Yii2使用自带的UploadedFile实现的文件上传
- Yii配置文件用法详解
- Yii2中YiiBase自动加载类、引用文件方法分析(autoload)
- Yii2实现UploadedFile上传文件示例
- YII中Ueditor富文本编辑器文件和图片上传的配置图文教程
- Yii框架中使用PHPExcel的方法分析
相关文章
php empty 函数判断结果为空但实际值却为非空的原因解析
这篇文章主要介绍了php empty 函数判断结果为空但实际值却为非空的原因解析,下面是脚本之家小编处理之后的调试记录,分享到脚本之家平台,感兴趣的朋友一起看看2018-05-05
php微信高级接口调用方法(自定义菜单接口、客服接口、二维码)
这篇文章主要为大家详细介绍了php微信高级接口调用方法,包括自定义菜单接口、客服接口、二维码等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-11-11
PHP htmlspecialchars() 函数实例代码及用法大全
这篇文章主要介绍了PHP htmlspecialchars() 函数实例代码及用法大全,需要的朋友可以参考下2018-09-09
Laravel第三方包报class not found的解决方法
今天小编就为大家分享一篇Laravel第三方包报class not found的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2019-10-10


最新评论