热门标签 | 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.     } 

推荐阅读
  • 本文探讨了如何在JavaScript中调用PHP函数及实现两者之间的有效交互,包括通过AJAX请求、动态生成JavaScript代码等方法。 ... [详细]
  • 本文旨在介绍Three.js的基础概念及其应用场景。Three.js是一个基于WebGL的JavaScript库,用于在网页上创建和显示3D图形。文中将从Canvas的基本功能出发,探讨其局限性,并引出WebGL及Three.js的解决方案。 ... [详细]
  • 解析程序员与软件工程师的角色差异
    本文深入探讨了程序员与软件工程师之间的主要区别,包括它们的职业定位、技能要求以及工作内容等方面的不同,旨在帮助读者更好地理解这两个角色的特点。 ... [详细]
  • 本文详细探讨了 Java 中 Daemon 线程的特点及其应用场景,并深入分析了 Random 类的源代码,帮助开发者更好地理解和使用这些核心组件。 ... [详细]
  • ThinkPHP 文件缓存组件详解与应用
    本文深入探讨了ThinkPHP框架中的文件缓存类实现,提供了详细的代码示例和使用说明,旨在帮助开发者更好地理解和利用这一功能来优化应用程序性能。 ... [详细]
  • ASP.NET Core Razor模型验证绑定是否造成服务器资源浪费?
    探讨了ASP.NET Core Razor页面中模型验证绑定机制是否导致了不必要的服务器负载。通过一个简单的登录表单示例,分析了模型验证的过程及其对服务器的影响。 ... [详细]
  • 本文探讨了如何利用 Application 对象在 PHP 应用程序中共享数据,特别是在多用户环境中保持数据的一致性和安全性。文章还介绍了 Application 对象的基本结构、方法和事件,并提供了实际应用示例。 ... [详细]
  • Java 动态代理详解与示例
    本文详细介绍了Java中的动态代理机制,包括如何定义接口、实现类和代理处理器,并通过具体示例演示了动态代理的创建和使用过程。 ... [详细]
  • LeetCode 6057: 计算与子树平均值相等的节点数量——深度优先搜索
    本题要求在给定的二叉树中找到所有符合条件的节点数量,即节点的值等于其所有后代节点(包括自身)值的平均值。这里的平均值是通过将所有后代节点值之和除以后代节点的数量,并向下取整得到。 ... [详细]
  • CSGO
    CSGOTimeLimit:40002000MS(JavaOthers)MemoryLimit:524288524288K(JavaOthers)ProblemDescriptio ... [详细]
  • 本文介绍了如何通过自定义View中的declare-styleable属性创建枚举类型,并在代码中访问这些枚举值的方法。 ... [详细]
  • 本文汇集了使用C#中不同HTTP客户端向Web API上传文件的实例,旨在为开发者提供实用的技术指南。 ... [详细]
  • 本文详细介绍了在PHP中如何创建新文件以及如何使自定义函数在整个项目中全局可用的方法,包括最新的实践技巧。 ... [详细]
  • 解决Android开发中的TextView难题
    探讨了在Android开发过程中遇到的关于TextView组件的常见问题,特别是如何实现多行文字的跑马灯效果,并提供了初步的解决方案和参考资料。 ... [详细]
  • Only2 Labs 是一家专注于视觉设计的工作室,如果您对当前的设计感到不满,或者急需寻找一个可靠的设计合作伙伴,甚至是您的团队项目需要专业指导,Only2 Labs 都将竭诚为您提供帮助。 ... [详细]
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社区 版权所有