1. 描述
有的时候有些js代码在cpt里可以运行成功,但是在决策报表里会没有效果,举例:
分页预览改变鼠标悬停所在行背景色的代码,在决策报表的报表块使用,预览时没有效果。
2. 思路
这是由于决策报表里没有加载结束后事件,只有初始化后事件,但是我们需要在决策报表加载结束后再执行这段代码,因此我们在代码前面加上setTimeout()延时函数就可以起作用了。
setTimeout(function(){ },1000);
注:setTimeout()延时函数支持移动端。
3. 操作步骤
1)新建决策报表,新建数据集ds1:SELECT * FROM 订单。
2)将报表块拖入报表主体,报表块设计如下:
3)返回表单,选中报表块,添加一个初始化后事件:
编辑该事件添加下面的js代码:
setTimeout(function() {
var background_color = "rgb(255,0,0)";
var frozen_back_color = new Array();
var back_color = new Array();
var $last_tr;
var i = 0;
$(".x-table tr").bind("mouseenter", function() {
if(typeof($last_tr) != "undefined") {
if(typeof($(this).attr("id")) != "undefined") {
if(typeof($("#content-container #frozen-west").attr("id")) != "undefined") {
$("#content-container #" + $last_tr.attr("id")).each(function() {
$(this).children("td").each(function() {
$(this).css("background-color", frozen_back_color[i][$(this).index()]);
});
i = i + 1;
});
i = 0;
} else {
$last_tr.children("td").each(function() {
$(this).css("background-color", back_color[$(this).index()]);
});
}
frozen_back_color = [];
back_color = [];
}
}
if(typeof($(this).attr("id")) != "undefined") {
if(typeof($("#content-container #frozen-west").attr("id")) != "undefined") {
$("#content-container #" + $(this).attr("id")).each(function() {
frozen_back_color[i] = new Array();
$(this).children("td").each(function() {
frozen_back_color[i][$(this).index()] = $(this).css("background-color");
$(this).css("background-color", background_color);
});
i = i + 1;
});
i = 0;
} else {
$(this).children("td").each(function() {
back_color[$(this).index()] = $(this).css("background-color");
$(this).css("background-color", background_color);
});
}
}
});
$(".x-table tr").bind("mouseleave", function() {
if(typeof($(this).attr("id")) != "undefined") {
$last_tr = $(this);
}
});
}, 1000);
4)保存模板预览。
4. 预览效果
4.1 PC端预览效果
4.2 移动端预览效果
注:示例中的js不支持移动端。
5. 已完成模板
模板效果在线查看请点击:决策报表里使用延时函数实现某些js效果.frm
已完成的模板,可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\JS\表单JS实例\27-决策报表里使用延时函数实现某些js效果.frm