反馈已提交

网络繁忙

单选按钮组控件的打印/导出

  • 文档创建者:RF
  • 历史版本:12
  • 最近更新:Tracy.Wang 于 2024-10-12
  • 1. 概述

    1.1 问题描述

    介绍填报时打印或导出复选框时,知道修改配置项的方法只支持打印或导出「复选按钮」与「复选按钮组」控件。

    但是在做一些报告、合同的时候,单元格中可能有「单选按钮组」控件,导出和打印时默认只显示选中的值,其他值不显示。

    那么该如何实现打印或导出所有的「单选按钮组」控件呢?

    1.2 解决思路

    导出和打印时,单元格值会受到形态设置的影响,那么可以通过设置单元格形态数据字典的显示值,利用搜狗输入法的特殊符号来实现。针对每一个不同的选择,分别设置不同的显示值选中状态。

    注:移动端没有打印的概念,该方案是支持 移动端导出 的。

    2. 示例

    2.1 报表设计

    建立数据集 ds1,通过 sql 取出 5 条数据:

    新建普通报表,B1 和 B2 单元格添加「单选按钮组控件」,表格样式如下图所示:

    设置 B1 和 B2 单元格的「单选按钮组控件」数据字典为 ds1,实际值和显示值都为产品名称字段,选择「自适应」:

    2.2 方法一:逐条设置形态

    选中B1单元格,选择「单元格属性>形态」,设置为「数据字典>自定义」。如下图所示:

    设置实际值和显示值如下表所示:

    实际值
    显示值
    苹果汁●苹果汁  ○牛奶  ○番茄酱  ○盐  ○麻油
    牛奶○苹果汁  ●牛奶  ○番茄酱  ○盐  ○麻油
    蕃茄酱○苹果汁  ○牛奶  ●番茄酱  ○盐  ○麻油
    ○苹果汁  ○牛奶  ○番茄酱  ●盐  ○麻油
    麻油○苹果汁  ○牛奶  ○番茄酱  ○盐  ●麻油

    上述输入显示值时,其中的 ● 和 ○ 是通过搜狗输入法的特殊字符输入的字符串,输入方式如下图所示:

    Snag_19f758b4.png

    2.3 方法二:统一设置形态

    方法一需要逐条设置,在单选按钮组控件的选项较多或者后续会变化的情况下不太好用,所以有另一种统一设置的办法,需要用到公式来判断处理。

    选中 B2 单元格,选择「单元格属性>形态」,设置为「数据字典>公式形态」。如下图所示:

    设置公式为joinarray(MAPARRAY(value("ds1", 2), if(item = $$$, "●", "○") + item), "  ")

    公式说明:

    value("ds1", 2) :取出 ds1 数据集的第二列「产品名称的所有值,返回值组成的数组

    MAPARRAY(value("ds1", "产品名称"), if(item = $$$, "●", "○") + item) :对数组进行遍历判断,如果为当前选中的值,则在前面插入●,其余值在前面插入

    joinarray(MAPARRAY(value("ds1", "产品名称"), if(item = $$$, "●", "○") + item), "  ") :将数组转为字符串,分隔符为空格

    2.4 效果预览

    保存报表,点击「填报预览」,效果如下图所示:

    点击「打印」或导出,Excel、Word 、PDF 和图片均可以正常导出,效果如下图所示:

    方法一:在按钮组控件未选择任何值的情况下不支持导出和打印

    方法二:在按钮组控件没有默认值,且预览后未编辑过的情况下不支持导出和打印

    3. 模板下载

    附件列表


    主题: 填报应用
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭



    AI

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持