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

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

一、14周年活动

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

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

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

二、场景应用

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

三、术经验分享

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

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

四、二次开发视频

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

、任务持续上线

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

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

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

麦粉社区
>
帖子详情

电子表格修改列表对话框样式

电子表格软件 发表于 2025-1-3 11:20
发表于 2025-1-3 11:20:39

如何修改列表对话框选中选项背景颜色

发表于 2025-1-3 11:20:40
本帖最后由 橘猫今天喝水了吗 于 2025-1-6 17:13 编辑

下拉框吗? 感觉可以通过appendCss来实现, 获取选框对象,设置onmouseover等属性。 有空了我试试


 


 


---20250106 更新


可以通过onmouseover属性实现,方法是通过获取选项内容标签,逐个增加属性,但是由于下拉框的组件是在点击下拉框后才会生成下拉列表,宏没有很好的类型来对应。只能通过先点击下拉框,生成选项之后,刷新页面,才会让宏里的操作生效。


这个方案pass掉。


 


最终办法是通过修改全局属性:增加hover属性实现。


 


创建客户端宏,(打开报表后或者每次刷新后都行)


代码实现过程如下:


版本1:


function main(spreadsheetReport) {

    var style = document.createElement('style'); //创建style
    style.type='text/css';
    var css = `
    .dropdown-box-span-select:hover {
        background-color:red
    }
    `
    style.appendChild(document.createTextNode(css));
    document.head.appendChild(style);

}

版本1代码说明:


首先创建一个style标签,再创建css内容。


css内容中:   【.dropdown-box-span-select】 是class选择器,我使用的是电子表格里的下拉框参数,下拉框中鼠标选中的标项的class会被系统修改为class='dropdown-box-span-select' (未被鼠标指向的项为dropdown-box-span)。


然后通过css设置 hover(鼠标指向时的属性) 的 background-color:red (背景颜色为红色)也可以设置其他样式内容。


 


缺点:由于document设置的是当前浏览器页面的全局属性,所以其他电子表格也会收到影响。


针对这个问题,修改代码,得到了版本2


版本2代码如下:


function main(spreadsheetReport) {

    var style = document.createElement('style'); //创建style
    style.type='text/css';
    var css = `
    table[class*='Iff808081019390ff90ff41ec01942ad3c4a2570c'] .dropdown-box-span-select:hover {
        background-color:red
    }
    `
    style.appendChild(document.createTextNode(css));
    document.head.appendChild(style);

}

版本2代码说明:


需要限制修改样式的内容只限于当前电子表格,那么需要根据id等唯一属性来限制,通过观察网页元素源码,看到了与当前电子表格相关的限制,在table标签里,有class的值中包含了电子表格属性中id。


(背景:Iff808081019390ff90ff41ec01942ad3c4a2570c 是我的电子表格的属性中id,也是全局资源唯一id。)


在版本1的基础上增加了一个祖先筛选table[class*='Iff808081019390ff90ff41ec01942ad3c4a2570c']


table[class*='电子表格的id']  :效果是筛选class名称中包含当前电子表格id的table标签。


后边空格再跟上.dropdown-box-span-select:hover


整体意思是祖先标签是class含Iff808081019390ff90ff41ec01942ad3c4a2570c的table,这个table下的class是dropdown-box-span-select 的元素,设置其hover属性


 


 


你需要注意的变量:


1.table:  内容应该都是在table中,如果你看网页源码,发现电子表格的内容标签的祖先们之中没有table,那你需要找到跟电子表格属性中id有关的最外层的那个标签, 形式如


class ='xxxxxx xxxIff808081019390ff90ff41ec01942ad3c4a2570c_xxx xxx' ... >  根据判断修改祖先标签


 


2.dropdown-box-span-select:我用电子表格的下拉框组件测试的,下拉框选项的class是这个,你可以根据实际情况来过滤其他class


3.background-color:red: 修改背景颜色为红色,这个可以替换或者增加其他属性。


回复

使用道具 举报

发表于 2025-1-3 12:42:03
这个怕是不行吧,蹲个看看
回复

使用道具 举报

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

本版积分规则

4回帖数 0关注人数 1622浏览人数
最后回复于:2025-1-3 13:45