麦粉社区
>
帖子详情

怎么实现页签控制本页面内所有组件的数据筛选

数据分析 发表于 2025-3-5 14:41
发表于 2025-3-5 14:41:37
本帖最后由 高 于 2025-3-10 15:34 编辑

部署了v10版本,公司大屏,一页有8个左右图表,顶部做了一行8个子公司名称的页签,希望功能是点击页签,页面内的所有数据筛选成这个公司的数据。这个怎么做到呀?


我了解的页签功能是绑定组件,总不能做8套一模一样的组件放在页面上吧……


———分割线———


感谢各位大佬的解答!


最后用的橘猫大佬的代码,v10和v11的一样,一开始在编辑页面保存刷新预览没有反应,退回到仪表盘大目录重新进去就可以执行了【也不知道为啥】


console测试不出来,加了个alert窗口用来测试


v10没有全局的筛选器,只能每个图表单独拉出筛选器具,需要定义多个otherportlet去识别,最后赋值多写几行就可以

发表于 2025-3-5 14:41:38
本帖最后由 橘猫今天喝水了吗 于 2025-3-7 17:20 编辑

点击页签,修改其他筛选组件的参数值。


效果图:





 


代码:




function main(page: IPage, portlet: IStaticTabsLinkPortlet) {
    let otherportlet = page.getPortletsByTitle('筛选_3')[0];
    portlet.setActiveTabNameChangeHandler((activeTabName) => {
        if (activeTabName ==0){
                value = '类别1';
        }else  if (activeTabName ==1){
                value = '类别2';
        }else  if (activeTabName ==2){
                value = '类别3';
        }else  if (activeTabName ==3){
                value = '类别4';
        }
        otherportlet.setValue([value]);
    })
}


 

代码说明:

1.这个宏是创建在你的页签组件中的,选择onAfterRender(组件渲染后)。


 

2. let otherportlet = page.getPortletsByTitle('筛选_3')[0];  这个是用来获取参数筛选器的。我的参数筛选器叫“筛选_3”,这个是组件的标题。

3.if代码块的作用是把页签的序号转为对应的参数值,因为页签的activeTabName 是从0开始的数字。

通过otherportlet.setValue([value]) 来改变参数筛选器的值。

    portlet.setActiveTabNameChangeHandler((activeTabName) => {

        if (activeTabName ==0){  //第1个页签

                value = '类别1';

        }else  if (activeTabName ==1){//第2个页签

                value = '类别2';

        }else  if (activeTabName ==2){//第3个页签

                value = '类别3';

        }else  if (activeTabName ==3){

                value = '类别4';

        }

        otherportlet.setValue([value]);

    })

}


  •   橘猫今天喝水了吗
    如果你知道如何获取页签名称,也可以直接将页签名称改为参数列表中对应的名称。就省掉了if语句块
    6 天前| 回复
  •   橘猫今天喝水了吗
    设置好之后,只需要将筛选器绑定到所有组件就行。页签不需要绑定任何组件
    6 天前| 回复
  •   高
    谢谢!我在v11验证成功了,但是本地部署的v10上无法实现,请问您知道原因吗?或者应该怎么调整?
    3 天前| 回复
  •   高
    啊没事了,我试验成功了~代码更新在原贴中
    3 天前| 回复
  •   橘猫今天喝水了吗
     回复 
    可能是版本差异,function main(page: IPage, portlet: IStaticTabsLinkPortlet) 
    开头的第一行,你换成v10版本的第一行试试。
    我再研究研究
    3 天前| 回复
  • 还有2条回复,点击查看

回复

使用道具 1 举报

发表于 2025-3-5 17:24:30
这个就是要将这个页签的名称传递给筛选器,但是这种得写宏代码了

回复

使用道具 1 举报

写宏代码,页签写click事件,点击不同页签给筛选器传不同机构的数值
回复

使用道具 1 举报

发表于 7 天前

为什么不设置成单选列表呢

  •   高
    因为不是一个表,是很多个表想要同时切换,而且我们布署的V10
    7 天前| 回复

回复

使用道具 举报

发表于 6 天前
写宏代码,click事件
回复

使用道具 1 举报

高级模式
B Color Image Link Quote Code Smilies
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

14回帖数 0关注人数 359浏览人数
最后回复于:6 天前
快速回复 返回顶部 返回列表