Dwz与thinkphp整合下的数据导出到Excel实例
ThinkPHP  /  管理员 发布于 9年前   223
             本文实例讲述了Dwz与thinkphp整合下的数据导出到Excel的方法。分享给大家供大家参考。具体方法如下: 这个问题困扰了我很久,终于还是自己写JQUERY把它搞掂了,希望能对遇到同样问题的人有所帮助,好吧,下面就是源代码: jquery代码如下: 希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
  
        //_getIds方法就是获取已选的要导出的数据的ID,设了两个参数selectedIds--已选id的input名称,targetType-->碎片模式,默认是navTab,如果是dialog的自行修改  
function _getIds(selectedIds,targetType){  
        var ids="";  
        var $box=targetType=="dialog"?$.pdialog.getCurrent():navTab.getCurrentPanel();  
        $box.find("input:checked").filter("[name='"+selectedIds+"']").each(function(i){  
  
            var val=$(this).val();  
            ids+=i==0?val:","+val;});  
            return ids;  
        }  
        //导出excel的按钮 class=iconn,click时触发  
$(".iconn").click(  
function(){  
//因为这个方法直运用到导出到excel 所以这里所需的参数变量我直接写死了  
var targetType="navTab";  
var selectedIds="ids";  
var postType="string";//批量选择的话,以文本的形式获取  
var ids=_getIds(selectedIds,targetType);  
if(!ids){  
alertMsg.error($(".iconn").attr("warn"));  
return false;  
//alert("请选择要导出的数据!");  
}else{  
//将获取到的ids 传给后台处理  
window.open("/index/art/memberExport/ids/"+ids);  
}  
  
});  
});
PHP代码如下:
复制代码 代码如下:
public function memberExport(){  
    $id=$_REQUEST['ids'];//获取已选数据的ID  
    //echo $id;  
  
//在这里导出到excel我没有用到phpexcel,是自己写的,很简单,相信大家都明白是什么意思,根据自己需要自行修改就行了  
    $filename=date('Y-m-d');  
    header("Pragma:public");  
header("Expires:0");  
header("Cache-Control:must-revalidate,post-check=0,pre-check=0");  
header("Content-Type:application/force-download");  
header("Content-Type:application/vnd.ms-execl;");  
header("Content-Type:application/octet-stream");  
header("Content-Type:application/download");  
header('Content-Disposition:attachment;filename="'.$filename.'.xls"');  
header("Content-Transfer-Encoding:binary");  
if(!$id){  
$this->error('非法操作!');  
}else{  
  
$map['id']=array('in',$id);  
$title="用户名\t 姓名\t 部门\t 职务\t 身份证\t 职称\t 学历\t 毕业时间\t 录用时间";  
$title=iconv('utf-8','gbk',$title);  
echo $title;  
set_time_limit(0);  
   $offset= 0;  
   $length=100;  
$Member = M('Member');  
$list=$Member->where($map)->order('id desc')->select();  
if(!$list){  
$this->error('操作错误!');  
}else{  
foreach($list as $key=>$row){  
echo "\n";  
echo iconv('utf-8','gbk',$row['username'])."\t";  
echo iconv('utf-8','gbk',$row['name'])."\t";  
echo iconv('utf-8','gbk',$row['department'])."\t";  
echo iconv('utf-8','gbk',$row['zhiwu'])."\t";  
echo iconv('utf-8','gbk',$row['sfz'])."\t";  
echo iconv('utf-8','gbk',$row['zhicheng'])."\t";  
echo iconv('utf-8','gbk',$row['xueli'])."\t";  
echo iconv('utf-8','gbk',$row['bytime'])."\t";  
echo iconv('utf-8','gbk',$row['lytime'])."\t";  
  
}  
$offset+=$length;  
}  
}  
}您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
			Copyright·© 2019 侯体宗版权所有·
			粤ICP备20027696号
			 
			
