反馈已提交

网络繁忙

JS实现下拉框自动展开

  • 文档创建者:axing
  • 历史版本:5
  • 最近更新:RosieY 于 2022-09-20
  • 1. 概述

    1.1 预期效果

    在使用下拉框做筛选查询时,需要点击下拉框下拉三角才会展开所有选项,有些使用场景下,用户希望自动展开选项列表,尤其是在多个控件联动场景下。如下图所示:

    地区控件选择地区后,销售员控件自动展开,并且选项为对应地区的销售员。如下图所示:

    自动展开.gif

    1.2 实现思路

    通过给地区控件添加编辑后事件实现。事件 JS 代码内容为自动展开下拉框选项。

    注:此方案不支持开启新计算引擎的模板和开启新参数样式的模板

    2. 示例

    2.1 准备数据

    新建模板,新建数据集 ds1,SQL 语句如下:

    SELECT distinct 地区 FROM 销量

    新建数据集 ds2,其中用了一个数据集参数「地区」,用来实现和地区控件联动,SQL 语句如下:

    select distinct 销售员 from 销量 where 1=1${if(len(地区)=0,""," and 地区 = '"+地区+"'")}

    2.2 添加控件

    1)在参数面板中添加「标签控件」、「下拉框控件」和查询按钮,对应修改标签控件和下拉框控件的名称。如下图所示:

    2)给地区下拉框控件绑定数据字典 ds1,给销售员下拉框控件绑定数据字典 ds2。如何绑定查看下图:

    地区下拉框控件:

    销售员下拉框控件:

    2.3 添加事件

    选中地区下拉框控件,在「控件设置>事件」处为其添加一个一个「编辑后」事件实现地区下拉框选择值后,展开销售员下拉框。如下图所示:

    注:如果自动展开影响到了联动效果,未完全联动完就实现了自动展开,可以将事件换成「编辑结束」事件。

    JavaScript 代码如下:

    var a = this.options.form.getWidgetByName("销售员");//获取销售员下拉框控件
    a.onTriggerClick();//展开下拉列表

    2.4 效果预览

    保存模板,点击「分页预览」。效果如下图所示:

    自动展开.gif

    注:不支持移动端。

    3. 模板下载

    点击下载模板JS实现下拉框自动展开.cpt

    附件列表


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

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

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

    不再提示

    10s后关闭

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