月下旬更新速递丨 实战场景深化、集成能力升级与开发进阶

初冬来临,一波热气腾腾的更新也准时抵达!我们聚焦实战技巧、集成增强与开发进阶,一系列新功能与新教程,助你在数据分析与系统开发的效率上再进一步。

一、实战技巧精讲

雷达图:多维度数据的“透视镜”,3步读懂数据真相》→ 聚焦雷达图核心应用场景,快速掌握多对象、多维度数据的可视化分析方法。

用图表解锁你的生活“数据密码”!》→ 探索图表在日常场景中的应用,让数据解读更直观、更具操作性。

二、直播上线

2025新特性实战解读(上)数据分析效率倍增秘籍》→ 解析2025新特性落地路径,助力实现数据分析效率成倍提升。

三、技术经验分享

【专家分享】数据排序的“权力游戏”:优先级规则决定谁先谁后》→解读高级排序的业务配置逻辑,让关键数据始终处于优先展示位置。

四、二次开发视频

扩展包开发知识点——前端改造》→从需求分析入手到最终实现的全流程讲解,帮助您快速入门上手Smartbi前端改造。

五、任务持续上线

【初级任务】解锁生活“数据密码”,可视化创意实践任务》→发起可视化创意任务,推动数据表达更生动、更具趣味性。

【初级任务】玩转雷达图解数据,200麦豆等你拿!》→推出雷达图实战任务,以激励方式提升多维数据分析技能。

六、全新素材上线

AD域(LDAP/LDAPS)登录验证V2》→扩展域账号登录支持,实现与企业Windows认证体系无缝对接。

数据模型:对接RestfulAPI接口》→打通数据模型与RestfulAPI对接通道,提升系统集成与数据获取效率。

计划任务:定时清空用户属性缓存→引入缓存自动清理机制,确保权限变更实时生效、业务数据及时更新。

用户同步:BI系统自定义用户所属组》→优化用户组同步逻辑,实现自定义组信息自动识别与补全。

审核流程:可以调用自助ETL》→增强审核流程集成能力,支持在用户任务节点直接调用自助ETL过程。

麦粉社区
>
帖子详情

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

数据分析 发表于 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关注人数 1698浏览人数
最后回复于:2025-3-7 17:08
快速回复 返回顶部 返回列表