决策报表的表格自动向上滚动问题

决策报表的表格向上自动滚动

image.png

FineReport 用户WtaQw4170 发布于 2020-5-26 09:25 (编辑于 2020-5-26 13:24)
1min目标场景问卷 立即参与
回答问题
悬赏:3 F币 + 添加悬赏
提示:增加悬赏、完善问题、追问等操作,可使您的问题被置顶,并向所有关注者发送通知
共3回答
最佳回答
0
lricLv6初级互助
发布于2020-5-26 09:26
最佳回答
0
anhuihaiwei2005Lv4见习互助
发布于2020-5-26 09:32

添加JS


if(window.interval2){clearInterval(window.interval2);}
setTimeout(function()
window.flag=true;
$("#frozen-center").mouseover(function(

window.flag=false
})
//鼠标悬停,滚动停止
$("#frozen-center").mouseleave(function(

window.flag=true
}) 
//鼠标离开,继续滚动
var old=-1
window.interval2=setInterval(function(
{
if(window.flag){
currentpos=$("#frozen-center")[0].scrollTop; 
if (currentpos==old){
$("#frozen-center")[0].scrollTop=0;

else
old=currentpos; 
$("#frozen-center")[0].scrollTop=currentpos+1.5

}
},25);
//以25ms的速度每次滚动3.5PX
},1000)

最佳回答
0
L大大Lv7高级互助
发布于2020-5-26 13:50

setTimeout(function() {

    var $report = $("div[widgetname=REPORT0]");

    //获取对应report的div元素

    var $scroll = $report.find(".reportContent");

    //获取对应report的div元素的滚动块元素,冻结为#frozen-center,未冻结且未安装自定义滚动条插件为.reportContent,未冻结且安装了自定义滚动条插件为.scrollDiv

    var flag = window.flag0;

    //设置全局变量flag,每个报表块需保证各不相同

    $report.find("#frozen-center").css('overflow-x', 'hidden');

    $report.find("#frozen-center").css('overflow-y', 'hidden');

    $report.find("#frozen-north").css('overflow-x', 'hidden');

    $report.find("#frozen-north").css('overflow-y', 'hidden');

    //冻结情况下隐藏滚动条

    $report.find(".reportContent").css('overflow-y', 'hidden');

    $report.find(".reportContent").css('overflow-x', 'hidden');

    //非冻结情况下隐藏滚动条

    flag = true;

    //定义全局参数flag,用来控制滚动的暂停和继续 (表单flag注意重复)

    $scroll.mouseover(function() {

        flag = false;

    })

    //鼠标悬浮,滚动停止

    $scroll.mouseleave(function() {

        flag = true;

    })

    //鼠标离开,继续滚动

    var old = -1;

    setInterval(function() {

        if (flag) {

            currentpos = $scroll[0].scrollTop;

            //获取距顶部距离

            if (currentpos == old) {

                $scroll[0].scrollTop = 0;

                //若已到达底部,则重置

            } else {

                old = currentpos;

                $scroll[0].scrollTop = currentpos + 1.5;

                //若未到达底部,则向下移动1.5像素

            }

        }

    }, 25);

    //以25ms的频率执行

}, 500);


  • 4关注人数
  • 739浏览人数
  • 最后回答于:2020-5-26 13:50
    请选择关闭问题的原因
    确定 取消
    返回顶部