十二月初新内容速递丨技术精进、实战赋能与开发深化

寒冬未至,学习不止!十二月上旬更新带来技术精进、实战赋能、场景课程与开发深化,助你在数据智能的道路上持续进阶!

一、场景化课程上线

驱动增长:汽车制造营销分析主题课程→聚焦汽车行业营销场景,学习如何利用数据驱动业务增长。

价值引擎:汽车制造财务分析主题课程→深入财务数据分析,助力企业价值挖掘与决策支持。

二、场景应用上线

【爆】券业“卷王”诞生!他竟与AI助手海誓山盟》→看券商如何玩转AI助手,提升服务智能化水平。

【词云图】三分钟,让你成为“文字淘金高手”》→快速上手词云图,轻松提取文本关键信息。

三、技术经验分享

版本更新/升级不用愁!这份方案大全请拿好》→系统升级不再迷茫,一站式解决方案助你顺利过渡。

告别“系统用不了”的无效沟通,Smartbi运维急救包请收好》→高效运维指南,帮你快速定位并解决系统使用中的常见问题。

四、二次开发视频

扩展包开发知识点——自定义module以及接口调用》→深入学习扩展包开发,掌握自定义模块与接口调用的核心技术

五、任务持续上线

场景实战系列:数据更新&校验,赢取278麦豆!》→掌握数据更新与校验核心技能,完成任务即获奖励。

场景实战系列:数据模型,赢取278麦豆!》→深入数据建模实战,提升数据架构能力。

200麦豆等你拿!词云在手,焦点立现》→轻松掌握词云图制作,视觉化呈现文本数据。

六、全新素材上线

防止数据过载:可配置的导入行数次数上限→ 灵活控制数据导入,保障系统稳定运行。

三权分立控制用户权限→ 细化权限管理,提升系统安全性与管理效率。


麦粉社区
>
帖子详情

tab页签如何根据权限进行显示隐藏

其它 发表于 2025-10-27 09:51
发表于 2025-10-27 09:51:29

仪表板中的tab页签,如何根据权限进行显示或者隐藏

发表于 2025-10-27 09:51:30
本帖最后由 wangxl 于 2025-10-27 16:50 编辑

function main(page: IPage, portlet: IStaticTabsPortlet) {
     // 获取当前用户
    var userService =  jsloader.imports("bof.usermanager.UserService").getInstance();
    var currentUser = userService.getCurrentUser();
    var allRoles = userService.getAllRolesOfUser(currentUser.id);
    // 获取所有角色名称
    var roleNames = []
    for (var i = 0; i < allRoles.length; i++) {
        roleNames = roleNames.concat(allRoles.name)
    }
    // 角色为【指定角色】,设置销售业绩排名按人员展示
    if (roleNames.indexOf('指定角色') > -1) {
        portlet.setActiveTabName("按人员")

        let otherPortlet1: IEChartsPortlet = page.getPortletsByTitle('销售业绩排名1')[0] // 按部门
        otherPortlet1.hide()
        let otherPortlet2: IEChartsPortlet = page.getPortletsByTitle('销售业绩排名2')[0] // 按人员
        otherPortlet2.show()
    }
}

可以参考下,如果组件多,建议还是分不同页面,维护简单。

回复

使用道具 1 举报

发表于 2025-10-27 10:18:00
描述一下使用场景呗
  •   Tom
    有一个大屏页面,上面有不同的模块,每个模块下方对应列表或者图标。期望目标:不同的人进来看到的模块是不一样的。想法是通过tab页签组件,写自定义宏,获取用户权限来进行tab页签的展示和隐藏。
    其他备选方案:上面放文本组件,点击文本进行切换,控制文本组件的显示隐藏,可能要多写一些宏代码。或者直接拆分不同页面进行权限控制。
    2025-10-27 10:21| 回复

回复

使用道具 举报

发表于 2025-10-27 16:22:50
楼上的备选方案我实现过,难度不高,但是架构设计起来比较复杂,有需要嘛
  •   Tom
    您好  太有需要了  谢谢
    2025-10-28 15:29| 回复
  •   Tom
    页面确实有点多 是十一个大的模块  要实现的话  的确有点难度
    2025-10-28 15:30| 回复
  •   玛卡巴卡的小推车
     回复 Tom
    1.先建一个模型,按顺序记录这十一个模块,设置一个参数做where条件,序号(int类型) in 参数1,需要一个空参数2,默认值是参数1的最小值。
    2.将11个模块做成11个仪表盘(子页面,分步加载,增加加载速度)
    3.新建主页面,做一个清单表放到画布外,然后把第一个模型的数据拖进来,规定好行号,拖入参数1。在画布上拖入11个文本框,用函数按顺序显示这11个模块名称。
    4.将11个子页面通过url接入进来,组件分别命名。
    5.拖入空参数2,在11个文本框上添加点击事件,根据文本内容向空参数2传值数字。在参数2上添加事件,根据值显示对应的url,其他的隐藏。
    6.在参数1上面添加宏,刚进入的时候根据数据值个数显示前几个文本框(由于清单表数据固定,由同一个参数控制,显示顺序不会变)。
    整体就是这么个流程,宏代码应该都能找得到,在稍加修改就行。
    2025-10-28 16:01| 回复

回复

使用道具 1 举报

发表于 2025-10-28 09:38:04
我也觉得分为不同的页面好,仅这一个页面还好说,换个体量,如果人多了,权限分类多了,组件内容多了,通过每个组件的宏不好控制,牵一发而动全身
回复

使用道具 举报

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

8回帖数 0关注人数 595浏览人数
最后回复于:2025-10-28 09:38
快速回复 返回顶部 返回列表