我有一个dgrid / OnDemandGrid。我还有一个下拉菜单,用于下载文件(XLSX,XLS和PDF文件类型)。
单击下拉菜单项,下载文件。
下载后,在OnDmandGrid上注册“dgrid-select”事件的侦听器根本不会被调用。
如果Form未提交,则调用dgrid-select事件侦听器,但我无法在不提交表单的情况下下载文件。
这就是网格的创建方式。
this.gridBoundaries = new (declare([Grid, Selection, Pagination, ColumnHider, Keyboard, ColumnResizer, editor]))({
// use Infinity so that all data is available in the grid
//className: "dgrid-autoheight",
showHeader: true,
collection: self.memStore,
bufferRows: Infinity,
columns: columns,
selectionMode: "single",
pagingLinks: true,
pagingTextBox: true,
firstLastArrows: true,
rowsPerPage: 100,
pageSizeOptions: [100, 150, 200],
adjustLastColumn : true,
loadingMessage: 'Loading data...',
noDataMessage: 'No data.'
},this.domNode);
this.gridBoundaries.startup();
表单提交下载是在以下代码段中触发
var formElement = dom.byId('exportForm');
if(formElement){
domAttr.set(formElement, "action", generateReportUrl);
domAttr.set(dom.byId("reportType"), "value", reportType)
domAttr.set(dom.byId("selectedSite"), "value", this.selectedSite.FAC_IDU)
domAttr.set(dom.byId("columnMetaData"), "value", columnMetaDatas)
domAttr.set(dom.byId("selectedMarketArea"), "value", this.selectedMarketArea.MRKT_AREA)
domAttr.set(dom.byId("tabSelected"), "value", isCustomer)
//domAttr.set(dom.byId("polygonJSON"), "value", this.polygonJSON)
domAttr.set(dom.byId("currentTimeZone"), "value", this.currentTimeZone)
domAttr.set(dom.byId("zoneId"), "value", this.zoneId)
formElement.submit();
}
答案 0 :(得分:0)
我认为你可能遇到了一个特殊且非常糟糕的IE故障,其中事件监听器绑定在“非导航”发生后被洗牌 - 我的意思是导航实际上不会将浏览器窗口发送到新的位置,例如<a href="javascript:...">
链接...和文件下载。
https://connect.microsoft.com/IE/feedback/details/802397/ie9-ie10-events-can-be-sent-to-the-wrong-listeners更具体地描述了这个问题。 (我很确定我也在IE11中看过它。)
至少要确认这是否是您遇到的问题,我建议将target="_blank"
添加到表单元素,以便技术上不会导航当前窗口。