Saiku如何固定查询结果table的表头和首列
在使用saiku查询的时候,当“行”和“列”的维度内容过多时,在查看时只看到数据,不知道是什么数据,维度不清楚,得来回拖动滚动条才行,所以同事提出想要固定“表头”和“首列”。
在网上找了一些现成的插件使用后效果都不理想,所以决定自己动手,丰衣足食。
我的思路来自:http://www.cnblogs.com/sorex/archive/2011/06/30/2093499.html
使用四个table,其中一个为saiku原有的,再增加3个,思路效果图:

js代码实现:
1.找到SaikuTableRenderer.js(此文件为saiku生成table的js文件)的“$(self._options.htmlObject).html(html)”代码(40行左右,作用为添加saiku原有table),在后面插入代码如下(作用为生成固定表头和首列用的3个div):
/*设置表头固定和首列固定代码-------------开始*/
$(self._options.htmlObject).parent().parent().css({"position":"relative","overflow":"hidden","padding-top":"0px"});
$(self._options.htmlObject).parent().height($(self._options.htmlObject).parent().parent().height());
$(self._options.htmlObject).parent().css({"position": "relative","overflow":"auto","z-index":"5"}); //添加固定表头div
var headerFixedDiv = $(self._options.htmlObject).parent().clone();
headerFixedDiv.find("tbody").css({"visibility":"hidden"});
headerFixedDiv.attr("id","headerFixedDiv");
$(self._options.htmlObject).parent().before(headerFixedDiv);
$("#headerFixedDiv").css({"position":"absolute","overflow":"hidden","z-index":"15"}); //添加固定首列div
var columnFixedDiv = $(self._options.htmlObject).parent().clone();
columnFixedDiv.find("thead").css({"visibility":"hidden"});
columnFixedDiv.find("thead .col").remove();
columnFixedDiv.find("tbody .data").remove();
columnFixedDiv.attr("id","columnFixedDiv");
$(self._options.htmlObject).parent().before(columnFixedDiv);
$("#columnFixedDiv").css({"position":"absolute","overflow":"hidden","z-index":"10"}); //添加固定表头和固定首列重叠部分div
var overlapFixedDiv = $("#headerFixedDiv").clone();
overlapFixedDiv.find("thead .col").remove();
overlapFixedDiv.find("tbody .data").remove();
overlapFixedDiv.attr("id","overlapFixedDiv");
$("#headerFixedDiv").before(overlapFixedDiv);
$("#overlapFixedDiv").css({"position":"absolute","overflow":"hidden","z-index":"20","background":"white"}); //调整固定表头和固定首列div的宽高
function resizeHeaderFixedDiv(){
var scrollBarWidth = $(self._options.htmlObject).parent()[0].offsetWidth - $(self._options.htmlObject).parent()[0].clientWidth;
var scrollBarHeight = $(self._options.htmlObject).parent()[0].offsetHeight - $(self._options.htmlObject).parent()[0].clientHeight; //设置固定表头div宽高
//判断是否出现纵向滚动条
if($(self._options.htmlObject).parent()[0].offsetHeight > $(self._options.htmlObject).parent()[0].clientHeight){
$("#headerFixedDiv").width($(self._options.htmlObject).parent().width()-scrollBarWidth);
}else{
$("#headerFixedDiv").width($(self._options.htmlObject).parent().width());
}
$("#headerFixedDiv").height($(self._options.htmlObject).find("thead").height()); //设置固定首列div宽高
//判断是否出现横向滚动条
if($(self._options.htmlObject).parent()[0].offsetWidth > $(self._options.htmlObject).parent()[0].clientWidth){
$("#columnFixedDiv").height($(self._options.htmlObject).parent().height()-scrollBarHeight);
}else{
$("#columnFixedDiv").height($(self._options.htmlObject).parent().height());
}
var columnFixedDivWidth = $("#columnFixedDiv").find("tbody tr:eq(0)")[0].offsetWidth;
$("#columnFixedDiv").width(columnFixedDivWidth);
$("#columnFixedDiv").find("thead tr").each(function(index){
$(this).height($("#headerFixedDiv").find("thead tr").eq(index).height());
}) //设置固定表头和固定首列重叠部分div宽高
$("#overlapFixedDiv").width($("#columnFixedDiv").width());
$("#overlapFixedDiv").height($("#headerFixedDiv").height());
$("#overlapFixedDiv").find("thead tr").each(function(index){
$(this).height($("#headerFixedDiv").find("thead tr").eq(index).height());
})
}
resizeHeaderFixedDiv(); //滚动条滚动事件
$(self._options.htmlObject).parent().scroll(function () {
$("#headerFixedDiv").scrollLeft($(self._options.htmlObject).parent().scrollLeft());
$("#columnFixedDiv").scrollTop($(self._options.htmlObject).parent().scrollTop());
}); //页面大小调整事件
$(window).resize(function(){
setTimeout(resizeHeaderFixedDiv, 250);
});
/*设置表头固定和首列固定代码-------------结束*/
2.找到Table.js的clearOut: function(){},在方法内添加代码如下(作用为清除上述代码生成的3个固定div):
//删除固定表头、首列及重叠部分div
var headerFixedDiv = document.getElementById("headerFixedDiv");
var columnFixedDiv = document.getElementById("columnFixedDiv");
var overlapFixedDiv = document.getElementById("overlapFixedDiv");
if(headerFixedDiv){
headerFixedDiv.remove();
}
if(columnFixedDiv){
columnFixedDiv.remove();
}
if(overlapFixedDiv){
overlapFixedDiv.remove();
}
3.找到index.html,找到.workspace_results table{margin-left:50px;}并注释掉,此代码为设置查询结果表距左侧长度,不注释掉的话在拖动滚动条的时候会有内容从表格左边溢出,也可以找其他方式解决,不如设置背景颜色为白色等。
实际效果图:

Saiku如何固定查询结果table的表头和首列的更多相关文章
- (转)supertable像excel那样固定table的表头和第一列
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"/> <title> ...
- H5手机开发锁定表头和首列(惯性滚动)解决方案
前端时间移动端在做表格的时候需要这个功能,由于还有实现类似原生的惯性滚动功能,于是使用了iscroll插件. iscroll插件下载地址:iscroll5 该功能demo github地址: http ...
- layui table表格 表头与内容列错位问题(只有纵向滚动条的情况)
版本2.4.5 问题展示: 存在问题:正好错位一个纵向滚动条的宽度 思路: 仔细观察th元素及th包裹的子元素div 如下图 发现th宽度莫名的就多了5px 我就纳闷了 解决方案:到table.js ...
- vue表格实现固定表头首列
前言 最近在做vue移动端项目,需要做一个可以固定表头首列的表格,而且由于一些原因不能使用任何UI插件,网上找了很久也没什么好方法,所以在解决了问题之后,写下了这篇文章供后来人参考,文章有什么错漏的问 ...
- html5 table的表头固定的HTML代码
table的表头固定的HTML代码 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...
- asp.net table表格表头及列固定实现
http://blog.csdn.net/zdw_wym/article/details/48630337 在开发中常会遇到table表格中列特别多,下拉后,表头就看不见了,水平滚动后,第1.2列就看 ...
- 非常强大的table根据表头排序,点击表头名称,对其内容排序
js代码: /** * 通过表头对表列进行排序 * * @param sTableID * 要处理的表ID<table id=''> * @param iCol * 字段列id eg: 0 ...
- js Table冻结表头示例代码
Table冻结表头的js实现代码. Table冻结表头: <script type="text/javascript"> //冻结table的表头 function ...
- layui table动态表头 改变表格头部 重新加载表格
改变头部原理: 删除原来表格, 重新建立DOM元素, 重新加载table,实现表头改变 明白了原理, 我相信大家都能写出来了, table.reload(ID, options)目前好像还不支持con ...
随机推荐
- python基础(四)
内置函数 callable() #判断是否能够被调用执行,可以调用返回True,例如函数和类 chr() #将ascii值转换为字符,例如print(chr(65) )输出为a ord()#将字符转换 ...
- python 初学笔记 (一)
初学python第一天,希望自己真正了解计算机语言,并且做出成效. 写下学习笔记,记录学习进度,娱乐学习,不断成长. python详细介绍: python是什么?运用到哪里?有哪些在使用它? pyth ...
- skynet配置文件
启动skynet需要一个配置文件 我们看下examples/config root = "./" 表示根目录是skynet启动时的目录thread = 8 ...
- Mac OS X 快捷键(完整篇)
不少朋友提出要求,希望有个「高质量」的列表.其实这样的资源真是太多,平果官网就有 快捷键文档(多国语言版本).于是花了20分钟,浏览了一些网站,整理了点资源放过来供大家参考. 快捷键是通过按下键盘上的 ...
- ceph rpm foor rhel6
ceph-0.86-0.el6.x86_64.rpm 09-Oct-2014 10:00 13M ceph-0.87-0.el6.x86_64.rpm 29-Oct-2014 13:38 13M ce ...
- BZOJ 3237([Ahoi2013]连通图-cdq图重构-连通性缩点)
3237: [Ahoi2013]连通图 Time Limit: 20 Sec Memory Limit: 512 MB Submit: 106 Solved: 31 [ Submit][ St ...
- Wormholes(SPFA+Bellman)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 36860 Accepted: 13505 Descr ...
- android实现点击短链接进入应用 并获得整个连接的内容
例如:我收到一个短信是一个链接:http://www.qq.com/a/b/?, 当我点击以后我要实现的场景是:点击----->有两种情况可供选择:手机中有此应用,跳转到应用:反之,则进入网页. ...
- C#程序之Main()方法
一.Main()方法的简介 1.一般情况下,一个C#可执行程序只有一个应用程序对象(也就是就程序入口),但是在某些情况,可能会有多个应用程序对象(程序入口),如单元测试中,这个时候我们就需要通过命令行 ...
- HBASE学习笔记--概述
定义: HBase是一个分布式的.面向列的开源数据库,HBase是Google Bigtable的开源实现,它利用Hadoop HDFS作为其文件存储系统,利用Hadoop MapReduce来处理H ...