反馈已提交

网络繁忙

当前为10.0版本文档,只有最新版本的文档支持在线编辑修改,如果想创建/编辑文档,请移步至 最新版帮助文档

JS实现首尾相接的跑马灯

  • 文档创建者:呆呆
  • 历史版本:25
  • 最近更新:帆软应用复用-Cat 于 2022-11-07
  • 1. 概述

    1.1 版本

    报表服务器版本
    功能变更
    10.0--

    1.2 预期效果

    在进行一些集团新闻内容展示时,可能需要一种首尾相接的跑马灯滚动效果,如下图所示:

    222

    1.3 实现思路

    单元格中添加 html 代码,用 html 显示内容,再配合 JS 实现滚动效果。

    2. 普通报表示例

    2.1 打开模板

    打开%FR_HOME%\webroot\WEB-INF\reportlets\demo\form\以html实现纵向跑马灯特效.cpt报表

    2.2 添加公式

    1)选中 B3 单元格,添加公式:"<div id=\"demo\" style=\"height:300px;overflow:hidden;\"> <div id=\"indemo\" style=\"height:200%;\"> <div id=\"demo1\"> <br />" + REPLACE(D3, ",", "<br /><br />") + "<br /><br /> </div> <div id=\"demo2\"></div> </div> </div>"

    注1:公式中使用 replace 函数将 D3 单元格的内容拼接到 HTML 语句中,如果数据内容不在 D3 单元格,需要修改。

    注2:公式中的 demo,demo1 ,demo2 会在后面 JavaScript 中引用,请不要改名字。

    1.png

    2)隐藏 D 列。

    2.3 设置 HTML 显示内容

    选中刚添加公式的 B3 单元格,在「单元格属性>其他 」位置,勾选「不自动调整」,将「显示内容」设置为「用 HTML 显示内容」,如下图所示:

    1.png

    2.4 添加 JS 事件

    点击菜单「模板>模板 Web 属性>分页预览设置」,选择「为该模板单独设置」,添加「加载结束」事件,如下图所示:

    2.png

    JavaScript 代码如下:

    setTimeout(function(){ 
    speed = 50; //滚动速度      
    var tab = document.getElementById("demo");//外层可视模块 
    var tab1 = document.getElementById("demo1");//内层滚动内容模块1
    var tab2 = document.getElementById("demo2");//内层滚动内容模块2 无缝对接到1后面的内容
    tab2.innerHTML = tab1.innerHTML;//克隆demo1为demo2
    tab.scrollTop = tab1.offsetHeight;
    //创建一个滚动函数,当滚动至demo1与demo2交界时,demo跳到最顶端
    function Marquee(){
        if (tab.scrollTop >= tab1.offsetHeight) {
            tab.scrollTop-=tab2.offsetHeight;
        }else{
            tab.scrollTop+=1;
        }
    }
    var MyMar=setInterval(Marquee,speed);
    },1500);
    //隐藏头尾空白行
    setTimeout(function(){        
    document.getElementById("r-1-0").style.height=0;
    },100);

    2.5 预览效果

    保存报表,点击「分页预览」,跑马灯效果如下图所示:

    动画2.gif

    3. 决策报表示例

    3.1 准备模板

    新建决策报表,添加绝对画布块与报表块,报表块 report0 中内容设置方法同普通报表,参考普通报表示例,不再详述,如下图所示:

    3.2 添加 JS 事件

    选中报表块 report0,添加「初始化后」事件,如下图所示:

    10.png

    JavaScript 代码如下:

    • 跑马灯不需要定时刷新

    setTimeout(function(){ 
    speed = 50; //滚动速度      
    var tab = document.getElementById("demo");//外层可视模块 
    var tab1 = document.getElementById("demo1");//内层滚动内容模块1
    var tab2 = document.getElementById("demo2");//内层滚动内容模块2 无缝对接到1后面的内容
    tab2.innerHTML = tab1.innerHTML;//克隆demo1为demo2
    tab.scrollTop = tab1.offsetHeight;
    //创建一个滚动函数,当滚动至demo1与demo2交界时,demo跳到最顶端
    function Marquee(){
        if (tab.scrollTop >= tab1.offsetHeight) {
            tab.scrollTop-=tab2.offsetHeight;
        }else{
            tab.scrollTop+=1;
        }
    }
    var MyMar=setInterval(Marquee,speed);
    },1500);
    //隐藏头尾空白行
    setTimeout(function(){        
    document.getElementById("r-1-0").style.height=0;
    },100);
    • 跑马灯需要定时刷新

    var form = this.options.form;
    setInterval(function() {
    form.getWidgetByName('report0').gotoPage(1, "{}", true);//刷新报表块,report0为报表块的控件名称
    $(".loading-ec-indicator").eq(0).remove();//移除刷新加载图片
    $(".text-indicator").remove();//移除正在加载文字
    setTimeout(function() {
    speed = 50; //滚动速度    
    var tab = document.getElementById("demo");//外层可视模块 
    var tab1 = document.getElementById("demo1");//内层滚动内容模块1
    var tab2 = document.getElementById("demo2");//内层滚动内容模块2 无缝对接到1后面的内容
    tab2.innerHTML = tab1.innerHTML;//克隆demo1为demo2
    tab.scrollTop = tab1.offsetHeight;
    //创建一个滚动函数,当滚动至demo1与demo2交界时,demo跳到最顶端
    function Marquee() {
    if (tab.scrollTop >= tab1.offsetHeight) {
    tab.scrollTop -= tab2.offsetHeight;
    } else {
    tab.scrollTop += 1;
    }
    }
    var MyMar = setInterval(Marquee, speed);
    }, 1000);
    }, 5000);

    3.3 预览效果

    保存模板,点击「PC端预览」,滚动不刷新效果如下图所示:

    动画3.gif

    保存模板,点击「PC端预览」,滚动同时刷新效果如下图所示:

    动画4.gif

    4. 模板下载

    1)普通报表已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\JS\分页预览JS实例\JS实现跑马灯效果一.cpt

    点击下载模板:JS实现跑马灯效果一.cpt

    2)决策报表已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\JS\表单JS实例\JS实现跑马灯效果二.frm

    点击下载模板:JS实现跑马灯效果二.frm


    附件列表


    主题: 报表应用
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览

    售前咨询电话

    400-811-8890转1

    在线技术支持

    请前往「服务平台」,选择「在线支持」

    热线电话:400-811-8890转2

    总裁办24H投诉

    热线电话:173-1278-1526