十一月上旬更新速递丨 数据与 AI 技术深耕、场景应用拓展与开发进阶实战

秋意正浓时,智能征程不止步!十一月上旬欢度14周年,聚焦数据与AI领域的知识深化、场景化应用落地、技术开发进阶,从理论到实战的全链路能力提升!

一、14周年活动

《14周年·探索乐章 | 寻藏宝图,挖掘社区金矿(已更新1-9关卡)开启一场知识寻宝探险之旅,重温与思迈特并肩成长的温暖时光!

《14周年·温情乐章|写下专属祝福,传递温暖情谊为思迈特14周年注入一份温度,也为这份同行之谊添上一抹亮色!

《14周年·荣誉乐章 | 星光致敬,表彰贡献榜样→回馈大家对社区生态的倾心建设,感谢每一位共建者的热忱与坚守!

二、场景应用

《构建“战略-业务-数据”三层指标体系(体系篇)》→“战略-业务-数据”三层指标体系是AIChat听懂的坚实的底层支撑。

三、术经验分享

《【专家分享】用Smartbi快速搞定数据刷新,老板看了都说好!》→掌握了数据刷新“提速”秘籍:告别滞后,让数据“实时在线”!

《【专家分享】数据排序的“权力游戏”:优先级规则决定谁先谁后》→提供了数据排序指南:破解多指令冲突,明确 “谁先生效”!

四、二次开发视频

扩展包开发前端改造了解前端改造的基本方法与实现流程、如何在Smartbi扩展包中修改CSS样式、扩展JS组件。

、任务持续上线

《【场景实战】数据驱动决策全流程实战:dws层数据处理》→深入数据决策,提升数据整合与维度设计能力,挑战成功即可获得麦豆奖励!

《【AIChat入门闯关计划】-随机掉落小测试》→快速检验AIChat知识漏洞,巩固核心概念。接受挑战即可获得麦豆奖励。

为进一步提升认证服务的质量与体验,我们对认证业务进行全面优化升级。更多详情请看Smartbi认证考试优化升级公告

麦粉社区
>
帖子详情

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

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