热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Dwz+thinkphp整合下的数据导出到Excel

这个问题困扰了我很久,终于还是自己写JQUERY把它搞掂了,希望能对遇到同样问题的人有所帮助,好吧,下面就是源代码:

这个问题困扰了我很久,终于还是自己写JQUERY把它搞掂了,希望能对遇到同样问题的人有所帮助,好吧,下面就是源代码:

jquery code:

  1. $(function(){ 
  2.  
  3.         //_getIds方法就是获取已选的要导出的数据的ID,设了两个参数selectedIds--已选id的input名称,targetType-->碎片模式,默认是navTab,如果是dialog的自行修改 
  4. function _getIds(selectedIds,targetType){ 
  5.         var ids=""
  6.         var $box=targetType=="dialog"?$.pdialog.getCurrent():navTab.getCurrentPanel(); 
  7.         $box.find("input:checked").filter("[name='"+selectedIds+"']").each(function(i){ 
  8.  
  9.             var val=$(this).val(); 
  10.             ids+=i==0?val:","+val;}); 
  11.             return ids; 
  12.         } 
  13.         //导出excel的按钮 class=iconn,click时触发 
  14. $(".iconn").click( 
  15. function(){ 
  16.                        //因为这个方法直运用到导出到excel 所以这里所需的参数变量我直接写死了 
  17. var targetType="navTab"
  18. var selectedIds="ids"
  19.                         var postType="string";//批量选择的话,以文本的形式获取 
  20. var ids=_getIds(selectedIds,targetType); 
  21. if(!ids){ 
  22. alertMsg.error($(".iconn").attr("warn")); 
  23. return false
  24. //alert("请选择要导出的数据!"); 
  25. }else
  26. //将获取到的ids 传给后台处理 
  27. window.open("__URL__/memberExport/ids/"+ids); 
  28.  
  29. }); 
  30. }); 

PHP code:

  1. //member成员信息导出到excel 
  2.     public function memberExport(){ 
  3.     $id=$_REQUEST['ids'];//获取已选数据的ID 
  4.     //echo $id; 
  5.  
  6. //在这里导出到excel我没有用到phpexcel,是自己写的,很简单,相信大家都明白是什么意思,根据自己需要自行修改就行了 
  7.     $filename=date('Y-m-d'); 
  8.     header("Pragma:public"); 
  9. header("Expires:0"); 
  10. header("Cache-Control:must-revalidate,post-check=0,pre-check=0"); 
  11. header("Content-Type:application/force-download"); 
  12. header("Content-Type:application/vnd.ms-execl;charset=gb2312"); 
  13. header("Content-Type:application/octet-stream"); 
  14. header("Content-Type:application/download"); 
  15. header('Content-Disposition:attachment;filename="'.$filename.'.xls"'); 
  16. header("Content-Transfer-Encoding:binary"); 
  17. if(!$id){ 
  18. $this->error('非法操作!'); 
  19. }else
  20.  
  21. $map['id']=array('in',$id); 
  22. $title="用户名\t 姓名\t 部门\t 职务\t 身份证\t 职称\t 学历\t 毕业时间\t 录用时间"
  23. $title=iconv('utf-8','gbk',$title); 
  24. echo $title
  25. set_time_limit(0); 
  26.    $offset= 0; 
  27.    $length=100; 
  28. $Member = M('Member'); 
  29. $list=$Member->where($map)->order('id desc')->select(); 
  30. if(!$list){ 
  31. $this->error('操作错误!'); 
  32. }else
  33. foreach($list as $key=>$row){ 
  34. echo "\n"
  35. echo iconv('utf-8','gbk',$row['username'])."\t"
  36. echo iconv('utf-8','gbk',$row['name'])."\t"
  37. echo iconv('utf-8','gbk',$row['department'])."\t"
  38. echo iconv('utf-8','gbk',$row['zhiwu'])."\t"
  39. echo iconv('utf-8','gbk',$row['sfz'])."\t"
  40. echo iconv('utf-8','gbk',$row['zhicheng'])."\t"
  41. echo iconv('utf-8','gbk',$row['xueli'])."\t"
  42. echo iconv('utf-8','gbk',$row['bytime'])."\t"
  43. echo iconv('utf-8','gbk',$row['lytime'])."\t"
  44.  
  45. $offset+=$length
  46.     } 

推荐阅读
  • 本文介绍了一段使用jQuery实现的用户注册页面表单验证代码,适用于前端开发人员学习和参考。该示例结合了HTML、CSS和JavaScript,确保用户输入的数据格式正确。 ... [详细]
  • 本文详细介绍了如何使用jQuery防止事件冒泡,确保子元素的点击事件不会触发父元素或祖先元素的相应事件。通过具体的代码示例和解释,帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • 优化网页加载速度:JavaScript 实现图片延迟加载
    本文介绍如何使用 JavaScript 实现图片延迟加载,从而显著提升网页的加载速度和用户体验。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 郑州大学在211高校中的地位与排名解析
    本文将详细解读郑州大学作为一所位于河南省的211和双一流B类高校,在全国211高校中的地位与排名,帮助高三学生更好地了解这所知名学府的实力与发展前景。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 优化ASM字节码操作:简化类转换与移除冗余指令
    本文探讨如何利用ASM框架进行字节码操作,以优化现有类的转换过程,简化复杂的转换逻辑,并移除不必要的加0操作。通过这些技术手段,可以显著提升代码性能和可维护性。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 电子元件封装库:三极管、MOS管及部分LDO(含3D模型)
    本资源汇集了常用的插件和贴片三极管、MOS管以及部分LDO的封装,涵盖TO和SOT系列。所有封装均配有高质量的3D模型,共计96种,满足日常设计需求。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
author-avatar
何卫先生
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有