如何解决点击按钮以在XPages中导出excel
我在网站https://www.xpagedomino.com/2015/02/xpage-export-to-excel-using-javascript.html
上找到了代码现在我有:
- 视图
- 一个按钮
我想使用按钮导出Excel。
以下是我已经尝试过的代码:
在按钮(客户端)中:
var viewPanel1Id = "view:_id1:viewPanel1"
var htmltable = document.getElementById(viewPanel1Id);
var html = htmltable.outerHTML;
window.open('data:application/vnd.ms-excel,' + encodeURIComponent(html));
但是按钮没有响应...
如何导出到excel ?????
以下是XPages的代码
<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core">
<xp:button value="Export5" id="button5">
<xp:eventHandler event="onclick" submit="true" refreshMode="complete">
<xp:this.action><![CDATA[#{javascript: var viewPanel = document.getElementById("#{id:viewPanel1}");
var html = viewPanel.outerHTML;
window.open('data:application/vnd.ms-excel,' + encodeURIComponent(html));}]]>
</xp:this.action>
</xp:eventHandler>
</xp:button>
<xp:viewPanel rows="30" id="viewPanel1" viewStyle="width:100%">
<xp:this.facets>
<xp:pager partialRefresh="true" layout="Previous Group Next"
xp:key="headerPager" id="pager1">
</xp:pager>
</xp:this.facets>
<xp:this.data>
<xp:dominoView var="view1" viewName="VEMPM03"></xp:dominoView>
</xp:this.data>
<xp:viewColumn columnName="LOCAL_PR_NO" id="viewColumn1"
showCheckbox="true">
<xp:viewColumnHeader value="prno" id="viewColumnHeader1"
showCheckbox="true">
</xp:viewColumnHeader>
</xp:viewColumn>
<xp:viewColumn columnName="PUR_DEPT_S01" id="viewColumn2">
<xp:viewColumnHeader value="pur" id="viewColumnHeader2">
</xp:viewColumnHeader>
</xp:viewColumn>
<xp:viewColumn columnName="ITEM_NAME" id="viewColumn3">
<xp:viewColumnHeader value="name" id="viewColumnHeader3">
</xp:viewColumnHeader>
</xp:viewColumn>
</xp:viewPanel>
</xp:view>
解决方法
您的按钮执行ServerSide脚本。使用
<xp:button value="Export5" id="button5">
<xp:eventHandler event="onclick" submit="false">
<xp:this.script><![CDATA[
var viewPanel = document.getElementById("#{id:viewPanel1}");
var html = viewPanel.outerHTML;
window.open('data:application/vnd.ms-excel,' + encodeURIComponent(html));]]>
</xp:this.script>
</xp:eventHandler>
</xp:button>
,
这可能无法解决您的问题,但是下面的行是通过csjs中的id引用元素的更好方法:
var viewPanel1Id = document.getElementById("#{id:viewPanel1}")
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。