解决:ShowModalDialog中的Excel导出窗口不能自动弹出以及翻页的问题

本文主要是介绍解决:ShowModalDialog中的Excel导出窗口不能自动弹出以及翻页的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近做一个项目遇到一个难题,我们的任务是在原平台上进行修改,满足现在需求。说是原平台,但那个平台根本就没有正式投入使用(据说是前面一个团队因为某种原因放弃继续开发了),也就是说很多功能都没有实现好。在这个项目中我们遇到了很多棘手的问题,在此都一一记录下。


问题1:模态对话框中搞定分页遇到“__doPostBack未定义”
ShowModalDialog显示模态对话框中我们放入了从数据库中检索出来的信息表,结果分页功能显示不了。政府部门用的是IE10浏览器(就是浏览器兼容性的问题),出现下面的问题“__doPostBack未定义”的解决办法。
解决办法:在网上找了很多解决方法,比如说.Net打补丁,结果很多都无济于事,最终决定先将浏览器设置成兼容模式将就用(后期有好的方法再改)。 用IE的兼容视图将你的网址添加到进去选择兼容模式即可!另外,在ShowModalDialog中实现分页必须加上如下代码:

<base target="_self">。

注:因为每次翻页都会刷新ShowModalDialog模态对话框,”target=”_self”就是刷新的目标ul是本身,这样才可以实现分页!
问题2: ShowModalDialog中的Excel导出窗口不能自动弹出点击导出按钮,会看见刷新但是闪跳一下就消失了,导出窗口看不见。
解决办法:突然想起为了让页面在列表头部分点击的时候有自动刷新但不弹出新页面的功能,特意在页面头部分添加了如下代码:

<base target="_self">。

把这行代码删除,发现刷新和导出都是可以的。但都会弹出一个页面。那就可以肯定是这里的问题了。而添加了这行代码后,导出会受到影响。
根据以往的经验,在ShowModalDialog添加一个iframe可以解决这个问题。
1、将如下代码放在头部分:

<base id="base_tag" target="_self" />  

注:如果不加这个在ShowModalDialog中分页功能无法实现(问题1中提到过)。
2、在body的末尾添加如下代码:

<iframe id="baseExportThis" name="baseExportThis" height="0px" width="0px"></iframe> 

注:height=”0px” width=”0px”就是使这个iframe不可见起到隐藏效果。
3、在导出按钮中作如下处理:

$('#base_tag').attr('target','baseExportThis');  
var temp = document.getElementById("form").action;  
document.getElementById("form").action =      "${root}/sci/exportMidscip.action";  
document.getElementById("form").submit();  
document.getElementById("form").action = temp;  
$('#base_tag').attr('target','_self');  

注:以上三步本以为可以解决我们的问题,但是令我们失望了!!!!在我们团队的不懈努力下我们想到了解决我们问题的办法。首先谈下为什么上面三步解决不了我们的问题。
以上三步正常解决ShowModalDialog中的Excel导出窗口弹出是没有任何问题的(说明下以上三步是我借鉴别人的)。但是我们使用此方法的时候会影响我们的表格的翻页效果,我们的导出按钮(函数)既调用了前台代码也调用了后台处理程序,原来程序中的代码如下:

<asp:ImageButton ID="ImageButton2" runat="server" ImageUrl="~/images/excel.gif"                                 OnClick="ImageButton2_Click"  />

我们在OnClick=”ImageButton2_Click” 后面加了一个Onclick=”export”,将第三步中的代码加export方法中,结果export方法根本就没有调用,最终解决方法是直接在程序中加入如下代码并且删除了export方法:

<script type="text/javascript">$(function(){$("#ImageButton2").click(function(){$('#base_tag').attr('target', 'baseExportThis');var temp = document.getElementById("form").action;document.getElementById("form").action = "${root}/sci/exportMidscip.action";document.getElementById("form").submit();document.getElementById("form").action = temp;$('#base_tag').attr('target', '_self');});});
</script>  

最终我们成功解决了问题2,在ShowModalDialog既实现了翻页,也实现了表格的导出!


下面写点题外话,我的项目总结(不爱看的可以不往下看了O(∩_∩)O哈!)。
这个项目是2015年10月11日接的,今天是2015年11月1日,历时21天。这其中大概有15天使浪费了,走了弯路,为什么呢?因为需求没搞明白!作为一个大三的我,第一次接外面项目,当然啊我主要是打下手,大部分难题是我崇拜的章老师解决的,我很佩服的老师,在我心目中,就没有他解决不了的问题。本来老师很有信心这个项目一个星期搞定的,最终实验证明,在需求明确的前提下这个项目一个星期我们是足以搞定的。但是,就是因为需求没搞明白,刚开始浪费了我们很长时间,这个项目我们算是第三手了,不对是第四手了,政府托付个人,个人托付给公司,公司外包给我们,O(∩_∩)O哈哈~,结果第三手在第二手那需求没搞清楚,外包给我们(第四手)需求没说清楚,我们就照我们的理解去做,遇到不懂的再问第三手,第三手也不懂,他们再问第二手之后转告给我们,就这样转来转去浪费了很多时间而且很多东西第三手理解不好传给我们就是有偏差的,经过几次交涉之后,第三手放弃了“中间件”功能,让我们有机会和第二手交涉了,那已经是项目接下后的半个月了。于是我们利用剩下的6天时间把项目完成了,前面15天做的工作基本上是没有用的!
这个经历告诉我们,以后再接任何项目的时候一定要和需求者当面谈,需求是很重要的,用我们老师的话说,软件开发需求分析占80%的时间,占80%的经历都不为过。总的来说,这是人生中的一次宝贵的经历,谢谢我的老师,在这也谢谢努力的自己,未来的日子继续加油!

这篇关于解决:ShowModalDialog中的Excel导出窗口不能自动弹出以及翻页的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/738289

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决