实现步骤
- 首先在电子表格设计器(Microsoft Office Excel)中,创建电子表格报表。表样如下:
2. 在浏览器的“分析展现”节点下,选中电子表格,右键选择 编辑宏 进入报表宏界面。
3. 在报表宏界面新建服务端模块。在弹出的新建模块对话框中,选择对象为spreadSheetReport、事件为onBeforeOutput、并把下面宏代码复制到代码编辑区域。
宏类型
类型 | 对象 | 事件 |
ServerSide | SpreadsheetReport | onBeforeOutput |
宏代码
代码块 | ||||
---|---|---|---|---|
| ||||
function main(spreadsheetReport) {
spreadsheetReport.printExpandedPositions();
} |
4.新建客户端模块。在弹出的新建模块对话框中,选择对象为spreadSheetReport、事件为onRender、并把下面宏代码复制到代码编辑区域,根据实际需要修改宏代码
宏类型
类型 | 对象 | 事件 |
ClientSide | SpreadsheetReport | onRender |
宏代码
代码块 | ||||
---|---|---|---|---|
| ||||
function main(spreadsheetReport, isAjaxRefreshCallback) {
spreadsheetReport.initTableGrid();
var A2List = spreadsheetReport.getExpandedPositions("A2"); //上半部分表格扩展字段起始位置
var A2_Start = spreadsheetReport.parseCellIndex(A2List[0])[0]; //解析出行号
var A2_End = spreadsheetReport.parseCellIndex(A2List[A2List.length - 1])[0];
var B7List = spreadsheetReport.getExpandedPositions("B7"); //下班部分表格扩展字段起始位置
var B7_Start = spreadsheetReport.parseCellIndex(B7List[0])[0]; //解析出行号
var B7_End = spreadsheetReport.parseCellIndex(B7List[B7List.length - 1])[0];
spreadsheetReport.addListener(spreadsheetReport.elemSheetFrame.contentWindow.document.body, "click",
function(e) {
var t = e.target;
while (t && t.tagName != "TR") {
t = t.parentNode;
}
if (!t) return;
var _focusTR = this._focusTR;
var startCol;
var endCol;
if (t.rowIndex >= A2_Start && t.rowIndex <= A2_End) {
this._focusTR = t;
startCol = 0; //上半部分表格起始列,从0开始计算
endCol = 3; //上半部分表格终止列,从0开始计算
}
if (t.rowIndex >= B7_Start && t.rowIndex <= B7_End) {
this._focusTR = t;
startCol = 0;
endCol = this.getColumnCount();
startCol = 1; //下半部分表格起始列,从0开始计算
endCol = 3; //下班部分表格终止列,从0开始计算
}
if (_focusTR) {
var rowTd = this.tableGrid[_focusTR.rowIndex];
for (var i = this._focusStartCol; i <= this._focusEndCol; i++) {
rowTd[i].style.backgroundColor = rowTd[i]._originalBackgroundColor
}
}
this._focusStartCol = startCol;
this._focusEndCol = endCol;
var rowTd = this.tableGrid[t.rowIndex];
for (var i = startCol; i <= endCol; i++) {
if (typeof rowTd[i]._originalBackgroundColor == "undefined") {
rowTd[i]._originalBackgroundColor = rowTd[i].style.backgroundColor;
}
rowTd[i].style.backgroundColor = "#abe5fe";
}
},
spreadsheetReport, "sheetFrameBody");
} |
示例资源:选中行高亮_多部分.xml
borderColor | #BBBBBB |
---|---|
bgColor | #F0F0F0 |
borderWidth | 1 |
borderStyle | solid |