三月上旬新内容速递丨选图攻略、内存优化与场景深化

春风送暖,学习相伴!三月上旬更新聚焦数据可视化选图、内存管理技巧、频率分析与桑基图应用,助你轻松驾驭数据分析新场景!

一、场景应用精选

【数析课堂】频率分析:用“数数”快速定位业务痛点》→通过频率统计,快速发现高频问题,精准定位业务改进点。
【桑基图】流动的“资金河流”,一眼看透业务流向》→学习桑基图绘制,追踪资金流动路径,洞察业务流转全貌。

二、技术经验分享

不止选类型,更要找对入口:数据分析选图全攻略》→深入讲解图表选择的核心逻辑,助你告别“图表选择困难症”。
内存溢出别慌张:教你如何看懂BI的“胃”,并管住它的“嘴”》→揭秘BI内存机制,掌握优化技巧,让分析更流畅。

四、社区日志更新

2026年「月更日志」社区更新合集 2.1 - 2.28》→汇总二月社区更新动态,记录成长每一步。

六、任务持续上线

【BI知识闯关】不止选类型,更要找对入口:数据分析选图全攻略》→通过闯关巩固选图知识,提升实战应用能力。
【数析课堂】频率分析知识巩固》→配套练习,加深频率分析理解,强化业务洞察。
【图表应用】桑基图追踪资金流向,发现业务奥秘》→动手实践桑基图,探索资金流向中的业务规律。
【BI知识闯关】内存溢出别慌张:教你如何看懂BI的“胃”,并管住它的“嘴”》→挑战内存管理知识,成为BI优化高手。


阳春三月,学习正当时,快来社区参与挑战,一起探索数据新视界!

麦粉社区
>
帖子详情

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

数据分析 发表于 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语句块
    2025-3-7 17:16| 回复
  •   橘猫今天喝水了吗
    设置好之后,只需要将筛选器绑定到所有组件就行。页签不需要绑定任何组件
    2025-3-7 17:27| 回复
  •   高
    谢谢!我在v11验证成功了,但是本地部署的v10上无法实现,请问您知道原因吗?或者应该怎么调整?
    2025-3-10 12:52| 回复
  •   高
    啊没事了,我试验成功了~代码更新在原贴中
    2025-3-10 15:05| 回复
  •   橘猫今天喝水了吗
     回复 
    可能是版本差异,function main(page: IPage, portlet: IStaticTabsLinkPortlet) 
    开头的第一行,你换成v10版本的第一行试试。
    我再研究研究
    2025-3-10 15:55| 回复
  • 还有2条回复,点击查看

回复

使用道具 1 举报

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

回复

使用道具 1 举报

发表于 2025-3-6 09:39:38
写宏代码,页签写click事件,点击不同页签给筛选器传不同机构的数值
回复

使用道具 1 举报

发表于 2025-3-6 14:48:42

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

  •   高
    因为不是一个表,是很多个表想要同时切换,而且我们布署的V10
    2025-3-6 15:58| 回复

回复

使用道具 举报

发表于 2025-3-7 09:27:27
写宏代码,click事件
回复

使用道具 1 举报

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

14回帖数 0关注人数 2447浏览人数
最后回复于:2025-3-7 17:08

社区

指南

AI

搜索

快速回复 返回顶部 返回列表