Cascader 级联选择器

优质
小牛编辑
116浏览
2023-12-01

当一个数据集合有清晰的层级结构时,可通过级联选择器逐级查看并选择。

基础用法

展示多个步骤。

options 需要遵循一定的结构,具体可见示例代码

<!--你可以通过绑定 (modelChange)=handle 来获得每次值改变的触发-->
<el-cascader [options]="options" (modelChange)="changeHandle($event)">
</el-cascader>
<script type="text">
  // in Component :
  options: any[] = [{
    value: 'zhinan',
    label: '指南',
    children: [{
      value: 'shejiyuanze',
      label: '设计原则',
      children: [{
        value: 'yizhi',
        label: '一致',
      }, {
        value: 'fankui',
        label: '反馈',
      }, {
        value: 'xiaolv',
        label: '效率',
      }, {
        value: 'kekong',
        label: '可控',
      }],
    }],
  }, {
    value: 'zujian',
    label: '组件',
    children: [{
      value: 'layout',
      label: 'Layout 布局',
    }, {
      value: 'color',
      label: 'Color 色彩',
    }, {
      value: 'typography',
      label: 'Typography 字体',
    }],
  }, {
    value: 'form',
    label: 'Form',
    children: [{
      value: 'radio',
      label: 'Radio 单选框',
    }, {
      value: 'checkbox',
      label: 'Checkbox 多选框',
    }, {
      value: 'input',
      label: 'Input 输入框',
    }, {
      value: 'input-number',
      label: 'InputNumber 计数器',
    }, {
      value: 'select',
      label: 'Select 选择器',
    }, {
      value: 'cascader',
      label: 'Cascader 级联选择器',
    }],
  }]
  
  changeHandle(event: { path: string[], value: string }): void {
    console.log(event)
  }
</script>

禁用选项

通过在数据源中设置 elDisabled 字段来声明该选项是禁用的

设置任意一项数据的 disabledtrue,即可禁用该项。

<el-cascader [options]="disabledOptions">
</el-cascader>
<script type="text">
  // in Component :
  disabledOptions: any[] = [{
    value: 'disabled',
    label: 'disabled',
    disabled: true,
  }, {
    value: 'normal',
    label: 'normal',
  }]
</script>

仅显示最后一级

可以仅在输入框中显示选中项最后一级的标签,而不是选中项所在的完整路径。

<el-cascader [options]="options"
  [all-levels]="false"
  (modelChange)="changeHandle($event)">
</el-cascader>
<script type="text">
  // in Component :
  changeHandle(event: { path: string[], value: string }): void {
    console.log(event)
  }
</script>

默认值

<!--增加默认值需要输入每一层选项的 value-->
<el-cascader [options]="options"
  [model]="['zujian', 'layout']"
  (modelChange)="changeHandle($event)">
</el-cascader>

选择即改变

点击或移入选项即表示选中该项,可用于选择任意一级菜单的选项。

设置属性的 [change-on-select]true 即可。

<el-cascader [options]="options"
  [change-on-select]="true"
  (modelChange)="changeHandle($event)">
</el-cascader>

Collapse Attributes

参数说明类型可选值默认值
options数据源Array
model默认绑定值,数组,每一项是数据中每一层的 valueArray
placeholder输入框占位文本string请选择
elDisabled是否禁用,在数据源 options 中设置boolean
clearable是否支持清空选项boolean
all-levels输入框中是否显示选中值的完整路径boolean1
change-on-select选择任意一级的选项立即得到反馈boolean
size尺寸stringlarge / small / mini
close主动关闭 cascader,非属性,实例方法() => void