解决: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

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

在Ubuntu上打不开GitHub的完整解决方法

《在Ubuntu上打不开GitHub的完整解决方法》当你满心欢喜打开Ubuntu准备推送代码时,突然发现终端里的gitpush卡成狗,浏览器里的GitHub页面直接变成Whoathere!警告页面... 目录一、那些年我们遇到的"红色惊叹号"二、三大症状快速诊断症状1:浏览器直接无法访问症状2:终端操作异常

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造