宜搭开发包
    正在准备搜索索引...

    年级选择组件

    该组件会根据当前日期自动计算当前年级,并生成相应的选项列表。默认情况下,年级范围为当前年级往前推共 6 年, 例如当前年级为 "2023级",则生成的选项列表为 ["2023级", "2022级", ..., "2018级"]。

    层级 (查看层级一览)

    索引

    构造函数

    属性

    fieldId: string = ""

    目标组件的 ID

    mode: "r" | "a" = "a"

    模式

    options: { text: string; value: string }[] = []

    组件选项列表,适用于下拉框、单选框等组件

    每个选项包含 text(显示文本)和 value(实际值)两个属性。

    preset: SchoolDaysPreset = {}

    预设配置项,可在实例化时传入,供 main() 方法使用

    range: number = 6

    跨越年份

    value: string = ""

    组件值

    方法

    • 将当前组件与另一个组件进行组合,生成一个新的虚拟组件

      组合逻辑为:将两个组件的值进行连接,生成新的值;将两个组件的选项进行笛卡尔积,生成新的选项列表;目标组件 ID 取当前组件和另一个组件中非空的那个。

      例如,若当前组件的值为 "2023-2024学年",选项为 [{ text: "2023-2024学年", value: "2023-2024学年" }], 另一个组件的值为 "第一学期",选项为 [{ text: "第一学期", value: "第一学期" }],则组合后的虚拟组件的值为 "2023-2024学年第一学期",选项为 [{ text: "2023-2024学年第一学期", value: "2023-2024学年第一学期" }]。

      参数

      返回 Readonly<VirtualComponent>

    • 将当前劫持组件转换为一个虚拟组件,并绑定到指定的目标组件 ID 上

      该方法会创建一个 VirtualComponent 实例,并将当前组件的值、选项和目标组件 ID 注入其中。 返回的 VirtualComponent 可以调用 setDefaultValue()setOptions() 方法,将值和选项注入到目标组件中。

      参数

      • fieldId: string

        目标组件的 ID

      返回 Readonly<VirtualComponent>

    • 组件主逻辑方法,负责生成年级选项列表和默认值

      该方法会根据当前日期计算当前年级,并生成相应的选项列表。默认情况下,年级范围为当前年级往前推共 6 年, 例如当前年级为 "2023级",则生成的选项列表为 ["2023级", "2022级", ..., "2018级"]。 其中,显示文本和实际值的格式取决于 mode

      • mode = "a" 时,显示文本和实际值均为 "YYYY级"。
      • mode = "r" 时,显示文本为 "一二三四五六七八九年级",实际值为 "2023级"、"2022级" 等。 默认值为当前年级。

      返回 Grade

    • 设置年级范围

      特别的,range 的有效区间为 [1, 9]。

      参数

      • range: number

        跨越年份,例如 range = 6 则生成当前年级及往前推共 6 年的选项

      返回 Grade