注意 | ||
---|---|---|
| ||
本文档的示例代码仅适用于本文档中的示例报表/场景。若实际报表/场景与示例代码无法完全适配(如使用功能不一致,或多个宏代码冲突等),需根据实际需求开发代码。 |
示例说明
客户需求:在电子表格报表中,存在 开始时间 及 结束时间 参数,客户的需求是开始时间不能大于结束时间,若大于则弹出提示。类似上述需求,可以参照如下方法进行设置。参考示例:
...
类型 | 对象 | 事件 |
---|---|---|
ClientSide | spreadsheetReport | onRenderReport |
宏代码
代码块 | ||||
---|---|---|---|---|
| ||||
function main(spreadsheetReport) {
spreadsheetReport._jhy_doRefresh = spreadsheetReport.doRefresh;
spreadsheetReport.doRefresh = function(fromButton, delayMask) {
var endtime = new Date(spreadsheetReport.getParameterValue("结束时间"));
var starttime = new Date(spreadsheetReport.getParameterValue("开始时间"));
if (endtime < starttime) {
//windowAlert("结束时间不能早于开始时间");
setTimeout(function() {
alert("结束时间不能早于开始时间");
}, 100);
return;
}
this._jhy_doRefresh(fromButton, delayMask);
}
}
|
注:如果电子表格设置了局部刷新,可参考以下宏代码(对象和事件不变)。
代码块 | ||
---|---|---|
| ||
function main(spreadsheetReport) {
spreadsheetReport.doRefreshSheet = function() {
if (this.autoRefresh == 1)
|
this.doRefresh();
else {
var endtime = new Date(spreadsheetReport.getParameterValue("结束日期"));
var starttime = new Date(spreadsheetReport.getParameterValue("开始日期"));
if (endtime < starttime) {
//windowAlert("结束时间不能早于开始时间");
setTimeout(function() {
alert("结束时间不能早于开始时间");
}, 100);
return;
}
this.doAjaxRefresh();
}
}
} |
注:结束时间减去开始时间大于90天时弹出提示,可参考以下宏代码。
...
代码块 |
---|
function main(spreadsheetReport) { spreadsheetReport._jhy_doRefresh = spreadsheetReport.doRefresh; spreadsheetReport.doRefresh = function(fromButton, delayMask) { var endtime = new Date(spreadsheetReport.getParameterValue("结束日期").replace(/\-/g, "/")); var starttime = new Date(spreadsheetReport.getParameterValue("开始日期").replace(/\-/g, "/")); if (endtime.getTime() - starttime.getTime() > 1000 * 3600 * 24 * 90) { //windowAlert("结束时间不能早于开始时间"); setTimeout(function() { alert("两个参数的差不能超过90天"); }, 100); return; } this._jhy_doRefresh(fromButton, delayMask); } } |
...