找回密码
 立即注册

QQ登录

只需一步,快速开始

Winny

超级版主

130

主题

246

帖子

1530

积分

超级版主

Rank: 8Rank: 8

积分
1530
Winny
超级版主   /  发表于:2023-8-1 17:32  /   查看:985  /  回复:0
本帖最后由 Winny 于 2023-8-1 17:32 编辑

在类Excel表格应用中,常用的需求场景是根据单元格之间的数据联动,例如选择某个省份之后,其它单元格下拉项自动扩展为该省份下的市区。excel中我们可以使用多种方式来实现,具体实现方式可自行百度。本文会从代码及UI层面讲解如何实现数据之间的多级联动。


1. UI实现多级数据联动。
Step1:设置数据;
按照如下形式设置数据,其中第一行为省份信息,剩余行中的内容为省份对应的市区信息
image.png484062804.png

Step2:添加名称管理器
按照如下操作,分别创建名称管理器,其中,名称管
理器名称为省份,引用区域为对应的省份区域。
6.gif486812133.png

Step3:添加一级数据验证
在该场景中,一级数据验证是省份信息,采用序列验证的形式来完成。
7.gif393093261.png

Step4: 添加二级数据验证
在该场景中,二级数据验证是指切换省份之后,代表地区的单元格下拉项随之更新,这里采用序列公式验证的形式来实现,对应的序列验证公式indirect()函数,详细操作如下:
8.gif942324523.png
这里需要注意的是,indirect函数中引用单元格需要根据需求设置好相对引用还是绝对引用。做好单个单元格的级联验证之后,如果想扩展到多行只需要利用spreadjs拖拽填充的功能即可,上图最后也给出了对应的操作。

2. 代码实现级联数据
代码实现整体与UI操作相吻合,只需要将对应的UI行为翻译为代码实现即可。详细代码如下:
Step1: 设置数据
  1. sheet.setArray(0,0,[
  2.     ["陕西省","江苏省"],
  3.     ["西安市","南京"],
  4.     ["宝鸡市","常州"],
  5.     ["汉中市","无锡"],
  6.     ["渭南市","苏州"],
  7.     ["延安市","泰州"],
  8.     ["商洛市","镇江"],
  9.     ["铜川市","宿迁"]
  10. ])
复制代码
Step2:设置名称管理器
  1. spread.addCustomName("陕西省","=Sheet1!$A$2:$A$8",0,0)
  2. spread.addCustomName("江苏省","=Sheet1!$B$2:$B$8",0,0)
复制代码

这里spread代表的是整个文件,名称管理器分为文件级和工作表级,这里用的是整个文件上的。
Step3: 设置一级数据验证
  1. let dv = GC.Spread.Sheets.DataValidation.createFormulaListValidator("=Sheet2!$A$1:$B$1");
  2. sheet.setDataValidator(0, 4, 10,1,dv,GC.Spread.Sheets.SheetArea.viewport);
复制代码
Step4:创建二级数据验证
  1. let dv2 = GC.Spread.Sheets.DataValidation.createFormulaListValidator("=indirect($E1)");
  2. sheet.setDataValidator(0, 5, 10,1,dv2,GC.Spread.Sheets.SheetArea.viewport);
复制代码

更加详细的示例可以点击这里跳转实战代码查看。




0 个回复

您需要登录后才可以回帖 登录 | 立即注册
返回顶部