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

推荐阅读
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 关羽败走麦城时路过马超封地 马超为何没有出手救人
    对当年关羽败走麦城,恰好路过马超的封地,为啥马超不救他?很感兴趣的小伙伴们,趣历史小编带来详细的文章供大家参考。说到英雄好汉,便要提到一本名著了,没错,那就是《三国演义》。书中虽 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 橱窗设计的表现手法及其应用
    本文介绍了橱窗设计的表现手法,包括直接展示、寓意与联想、夸张与幽默等。通过对商品的折、拉、叠、挂、堆等陈列技巧,橱窗设计能够充分展现商品的形态、质地、色彩、样式等特性。同时,寓意与联想可以通过象形形式或抽象几何道具来唤起消费者的联想与共鸣,创造出强烈的时代气息和视觉空间。合理的夸张和贴切的幽默能够明显夸大商品的美的因素,给人以新颖奇特的心理感受,引起人们的笑声和思考。通过这些表现手法,橱窗设计能够有效地传达商品的个性内涵,吸引消费者的注意力。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • faceu激萌变老特效的使用方法详解
    本文介绍了faceu激萌变老特效的使用方法,包括打开faceu激萌app、点击贴纸、选择热门贴纸中的变老特效,然后对准人脸进行拍摄,即可给照片添加变老特效。操作简单,适合新用户使用。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
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社区 版权所有