九月上旬更新速递丨 AI赋能、技术实战与智能探索

AI浪潮席卷,九月更新携智能发布会、实战经验与开发进阶强势登场!助您紧跟技术前沿,玩转数据智能!

重点推荐AI发布会火热预热!Agent BI是什么?Smartbi AIChat 全新升级发布会为您揭晓!

现有预热活动【智能体降临,未来已来!】解锁Smartbi AIChat V4超能力,参与即有机会赢专属好礼,抢先体验AI新纪元!更推出全新《十分钟完整体验AIchat》课程视频,仅需10分钟,即可使用本地数据快速体验AIChat全部功能,轻松入门智能分析!

一、任务持续上线

特征工程和数据预处理有什么区别?强化记忆,巩固学习成果。
SmartBI玩转Top N分析,轻松揪出数据》→检验分析能力,突破业务洞察瓶颈。

二、实战技巧分享

SmartBI同比环比分析大揭秘:让数据“笑”出真相!》→让数据不再沉闷,让趋势跃然纸上!

SmartBI玩转Top N分析,轻松揪出数据"尖子生"!》→面对海量数据,如何高效地提取最有价值的信息,快速识别关键数据项

、开发技能突破

扩展包简介→通过了解扩展包的实现原理和作用,让我们对扩展包有大致的认知。

四、AI每日一学

LLM 中的 Token 和 Embedding 到底是啥?》→深入浅出解析自然语言处理中的基础概念,夯实AI理解基石。

特征工程和数据预处理有什么区别?→厘清特征处理与数据清洗的边界,为模型训练铺平道路。

注意力机制、自注意力机制、多头注意力揭秘Transformer核心机制,助力理解现代AI模型架构。


为进一步提升认证服务的质量与体验,我们对认证业务进行全面优化升级。更多详情请看→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关注人数 1293浏览人数
最后回复于:2025-3-7 17:08
快速回复 返回顶部 返回列表